实验4 “0-1”背包问题(2)

2021-02-21 14:14

}

for(i = n-1; i >= 1; i--) //控制物品的循环,从i-1到第1件

{

for(j = 0; j < w[i]; j++) //贪心法把此行注释

m[i][j]=m[i+1][j]; //贪心法把此行注释

for(j=w[i]; j<=c; j++)

m[i][j]=max(m[i+1][j], m[i+1][j-w[i]]+v[i]);

}

for(i = 1; i < n; i ++) //构造最优解

{

if(m[i][c] == m[i+1][c])

x[i] = 0;

else

{

x[i] = 1;

c = c-w[i];

}

}

x[n] = (m[n][c])?1:0; //m[n][c]大于0吗?大于就是选了

return;

}

void main()

{

int i=0,n=7;

int w[]={0,2,3,5,7,1,4,1};

int v[]={0,10,5,15,7,6,18,3};

int x[]={0,0,0,0,0,0,0,0};

cout<<"程序自带数据为:"<<"\n";

cout<<"编号 重量 价值"<<endl;

for ( i=0;i<n;i++)

{

cout<<" "<<i+1<<" "<<w[i+1]<<" "<<v[i+1]<<endl;

}

int m=15;

int array[8][100]={0};

ZeroOneBag(v,w,x,m,7,array);

cout<<"\n背包能装的最大价值为: "<<array[1][m];

cout<<"\n\n最优解为:";

for(i = 1; i <= n; i++)

cout<<" "<<x[i]<<" ";

cout<<"\n\n";

system("pause");

}


实验4 “0-1”背包问题(2).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:人格心理学之特质理论

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: