
经典背包
#define mm(a) memset(a,0,sizeof(a));
#define max(x,y) (x)>(y)?(x):(y)
#define min(x,y) (x)<(y)?(x):(y)
#define Fopen freopen("1.in","r",stdin); freopen("m.out","w",stdout);
#define rep(i,a,b) for(ll i=(a);i<=(b);i++)
#define per(i,b,a) for(ll i=(b);i>=(a);i--)
#include<bits/stdc++.h>
typedef long long ll;
#define PII pair<ll,ll>
using namespace std;
const int INF=0x3f3f3f3f;
const int MAXN=(int)2e6+5;int a[MAXN],v[MAXN],w[MAXN],n,x,dp[MAXN],m;
int main() {scanf("%d",&m);while(~scanf("%d",&x))a[++n]=x;n>>=1;for(int i=1; i<=n; i++)w[i]=a[i],v[i]=a[i+n];for(int i=1;i<=n;i++){for(int j=m;j>=w[i];j--){dp[j]=max(dp[j],dp[j-w[i]]+v[i]);}}int ans=0;for(int i=0;i<=m;i++)ans=max(ans,dp[i]);printf("%dn",ans);return 0;
}
转载于:.html
本文发布于:2024-01-28 07:49:10,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/17063993545898.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
| 留言与评论(共有 0 条评论) |