首页 > 代码库 > SDJZU_新生_背包_HDU 2602 Bone Collector
SDJZU_新生_背包_HDU 2602 Bone Collector
Bone Collector
Crawling in process...Crawling failedTime Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64uDescription
Many years ago , in Teddy’s hometown there was a man who was called “Bone Collector”. This man like to collect varies of bones , such as dog’s , cow’s , also he went to the grave …
The bone collector had a big bag with a volume of V ,and along his trip of collecting there are a lot of bones , obviously , different bone has different value and different volume, now given the each bone’s value along his trip , can you calculate out the maximum of the total value the bone collector can get ?
The bone collector had a big bag with a volume of V ,and along his trip of collecting there are a lot of bones , obviously , different bone has different value and different volume, now given the each bone’s value along his trip , can you calculate out the maximum of the total value the bone collector can get ?
Input
The first line contain a integer T , the number of cases.
Followed by T cases , each case three lines , the first line contain two integer N , V, (N <= 1000 , V <= 1000 )representing the number of bones and the volume of his bag. And the second line contain N integers representing the value of each bone. The third line contain N integers representing the volume of each bone.
Followed by T cases , each case three lines , the first line contain two integer N , V, (N <= 1000 , V <= 1000 )representing the number of bones and the volume of his bag. And the second line contain N integers representing the value of each bone. The third line contain N integers representing the volume of each bone.
Output
One integer per line representing the maximum of the total value (this number will be less than 231).
Sample Input
1 5 10 1 2 3 4 5 5 4 3 2 1
Sample Output
14
#include<stdio.h> #include<string.h> #include<algorithm> using namespace std; int main() { int n; scanf("%d",&n); while (n--) { int N,V; scanf("%d%d",&N,&V); int i,j,k,m,vi[10007],wi[10007],dp[10007]; memset(dp,0,sizeof(dp)); for(i=1;i<=N;i++) { scanf("%d",&wi[i]); } for(i=1;i<=N;i++) { scanf("%d",&vi[i]); } for(i=1;i<=N;i++) { for(j=V;j>=vi[i];j--) { dp[j]=max(dp[j],dp[j-vi[i]]+wi[i]); } } printf("%d\n",dp[V]); } return 0; }
/*调了好多遍,最后我雨给我又调了一遍,发现一开始看错题意了。*/
/*下面是用结构体做的,原理一样,只不过用上了结构体而且删除了c++的部分。*/
#include<stdio.h>#include<string.h>int dp[1007];struct sa{ int W,V;}data[1007];int max(int a,int b){ return a>b?a:b;}int main(){ int t,i,j; scanf("%d",&t); while(t--) { memset(dp,0,sizeof(dp)); int n,v; scanf("%d%d",&n,&v); for(i=1;i<=n;i++) scanf("%d",&data[i].W); for(j=1;j<=n;j++) scanf("%d",&data[j].V); for(i=1;i<=n;i++) for(j=v;j>=data[i].V;j--) { dp[j]=max(dp[j],dp[j-data[i].V]+data[i].W); } printf("%d\n",dp[v]); } return 0;}
SDJZU_新生_背包_HDU 2602 Bone Collector
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。