http://zhidao.baidu.com/link?url=2LBDkW55tL2M8DgyKk3qCGtZPo_pWD-erb6LM1OHf0DgkFmpQMjNuHuhEipIpCV-GjK5JcHFSufp3dscoryyYmYBu5YXTVw44lEBrtPDSme
#include <stdio.h>
#include <conio.h>#include <string.h>
int f[1010],w[1010],v[1010];//f記錄不同承重量揹包的總價值,w記錄不同物品的重量,v記錄不同物品的價值
int max(int x,int y){//返回x,y的最大值
if(x>y) return x;
return y;
}
int main(){
int t,m,i,j;
memset(f,0,sizeof(f)); //總價值初始化爲0
scanf("%d %d",&t,&m); //輸入揹包承重量t、物品的數目m
for(i=1;i<=m;i++)
scanf("%d %d",&w[i],&v[i]); //輸入m組物品的重量w[i]和價值v[i]
for(i=1;i<=m;i++){ //嘗試放置每一個物品
for(j=t;j>=w[i];j--){
f[j]=max(f[j-w[i]]+v[i],f[j]);
//在放入第i個物品前後,檢驗不同j承重量揹包的總價值,如果放入第i個物品後比放入前的價值提高了,則修改j承重量揹包的價值,否則不變
}
}
printf("%d",f[t]); //輸出承重量爲t的揹包的總價值
printf("\n");
getch();
return 0;
}