标签:ems 并且 out 数组 memset for tac clu stack
#include <bits/stdc++.h>
using namespace std;
int v[1000],dp[1000000],bk[1000][1000];
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int n,m;
while(cin>>m>>n)
{
memset(dp,0,sizeof(dp));
memset(bk,0,sizeof(bk));
stack<int> st;
for(int i=1;i<=n;i++)
cin>>v[i];
for(int i=1;i<=n;i++)
for(int j=m;j>=v[i];j--)
if(dp[j]<dp[j-v[i]]+v[i])
{
bk[j][i]=1;
dp[j]=dp[j-v[i]]+v[i];
}
for(int i=n,j=m;i>=1;i--)
if(bk[j][i])
st.push(v[i]),j-=v[i];
while(st.size())
{
cout<<st.top()<<" ";
st.pop();
}
cout<<"sum:"<<dp[m]<<"\n";
}
}
标签:ems 并且 out 数组 memset for tac clu stack
原文地址:https://www.cnblogs.com/baccano-acmer/p/10227387.html