01背包做法 30pts 求调
查看原帖
01背包做法 30pts 求调
743593
xiarui1楼主2024/9/17 20:36

rt

#include <bits/stdc++.h>
using namespace std;
#define int long long
struct node{
	vector<int>v;
	int x;
}dp[10010];
int n;
signed main(){
	cin>>n;
	for(int i=0;i<=n;i++){
		dp[i].x=1;
	}
	for(int i=1;i<=n;i++){
		for(int j=n;j>=i;j--){
			if(dp[j].x<dp[j-i].x*i){
				dp[j].x=dp[j-i].x*i;
				dp[j].v=dp[j-i].v;
				dp[j].v.push_back(i);
			}
		}
	}
	for(int i=0;i<dp[n].v.size();i++){
		cout<<dp[n].v[i]<<" ";
	}
	cout<<"\n"<<dp[n].x;
	return 0;
}

2024/9/17 20:36
加载中...