[TIOJ] 1407. Striker的秘密 - EXTREME
題目連結:http://tioj.infor.org/problems/1407
跟TIOJ 1387一樣,只是把N改大一點。不過如果C在大一點就要好好的對餘數作單調隊列優化。
跟TIOJ 1387一樣,只是把N改大一點。不過如果C在大一點就要好好的對餘數作單調隊列優化。
#include <bits/stdc++.h>
using namespace std;
typedef pair<int,int> PII;
#define PB push_back
#define FF first
#define SS second
vector<PII> stones;
int dp[1000005];
int main(){
ios_base::sync_with_stdio(0);cin.tie(0);
int n, t;cin>>n;
for(int i=0;i<n;i++){
int w,m,c,j;cin>>w>>m>>c;
for(j=1;j<=c;c-=j, j<<=1)
stones.PB({w*j, m*j});
if(c) stones.PB({w*c, m*c});
}
for(int i=1;i<=t;i++) dp[i]=0;
cin>>t;
for(int i=1;i<=int(stones.size());i++)
for(int j=t;j-stones[i-1].FF>=0 && j>=1;j--)
dp[j] = max(dp[j-stones[i-1].FF] + stones[i-1].SS, dp[j]);
int ans=0;
for(int i=1;i<=t;i++) ans = max(ans, dp[i]);
cout<<ans<<'\n';
return 0;
}
留言
張貼留言