01揹包代碼

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;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章