[TIOJ] 1407. Striker的秘密 - EXTREME

題目連結:http://tioj.infor.org/problems/1407
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;
}

留言

這個網誌中的熱門文章

[TIOJ] 1094. C.幼稚國王的獎賞

[IOJ] 19. 啦啦啦

[IOJ] 14. 費氏數列問題