标签:
http://acm.hdu.edu.cn/showproblem.php?pid=2546
Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 17947 Accepted Submission(s): 6258
还是简单的01背包 但是有个坑 当m<5时 直接输出m
这题可以让重量跟价值一样 求背包
先求出m-5的数量 再减去一个最大值
#include<stdio.h> #include<string.h> #include<stdlib.h> #include<math.h> #include<algorithm> #include<iostream> using namespace std; #define N 1100 int dp[N]; int main() { int n,m,w[N],v[N]; while(scanf("%d",&n),n) { for(int i=0;i<n;i++) { scanf("%d",&w[i]); if(w[i]>w[0]) swap(w[i],w[0]); } for(int i=0;i<n;i++) v[i]=w[i]; scanf("%d",&m); if(m<5) { printf("%d\n",m); continue; } m=m-5; memset(dp,0,sizeof(dp)); for(int i=1;i<n;i++) { for(int j=m;j>=0;j--) { if(j>=w[i]) dp[j]=max(dp[j],dp[j-w[i]]+v[i]); } } printf("%d\n",m+5-dp[m]-w[0]); } return 0; }
标签:
原文地址:http://www.cnblogs.com/linliu/p/5037171.html