0-1背包 穷举版
来源:互联网 发布:头部按摩器 知乎 编辑:程序博客网 时间:2024/06/05 19:23
#include<stdio.h>
int f(int tmp);
int max();
int s[50];
int n,c;
int num=1;
int p[12];
int w[12];
int zhong[10000]={0};
int tmp=1;
int end[20]={0};
int q=0;
int main()
{
int i,j;
while(1)
{
scanf("%d %d",&n,&c);
num=1;
if(n==0 && c==0)
{
break;
}
for(i=1;i<=n;i++)
{
scanf("%d",&w[i]);
}
for(i=1;i<=n;i++)
{
scanf("%d",&p[i]);
}
f(1);
num=num-1;
max();
for(i=0;i<=20;i++)
{
zhong[i]=0;
}
}
for(i=0 ;i < q;i++)
{
printf("%d\n",end[i]);
}
return 0;
}
int f(int tmp)
{
int i;
int wight=0;
if(tmp == n+1)
{
for(i=1;i<=n;i++)
{
zhong[num]=zhong[num]+s[i]*p[i];
}
for(i=1;i<=n;i++)
{
wight=wight+s[i]*w[i];
}
if(wight<=c)
{
num=num+1;
}
else
{
zhong[num]=0;
}
return 0;
}
for(i=0;i<=1;i++)
{
s[tmp]=i;
f(tmp+1);
}
}
int max()
{
int i,j;
int flag=1;
for(i=1;i<=num;i++)
{
flag=1;
for(j=1;j<=num;j++)
{
if(zhong[i] < zhong[j])
{
flag=0;
}
}
if(flag == 1)
{
end[q]=zhong[i];
q=q+1;
}
}
return (0);
}
int f(int tmp);
int max();
int s[50];
int n,c;
int num=1;
int p[12];
int w[12];
int zhong[10000]={0};
int tmp=1;
int end[20]={0};
int q=0;
int main()
{
int i,j;
while(1)
{
scanf("%d %d",&n,&c);
num=1;
if(n==0 && c==0)
{
break;
}
for(i=1;i<=n;i++)
{
scanf("%d",&w[i]);
}
for(i=1;i<=n;i++)
{
scanf("%d",&p[i]);
}
f(1);
num=num-1;
max();
for(i=0;i<=20;i++)
{
zhong[i]=0;
}
}
for(i=0 ;i < q;i++)
{
printf("%d\n",end[i]);
}
return 0;
}
int f(int tmp)
{
int i;
int wight=0;
if(tmp == n+1)
{
for(i=1;i<=n;i++)
{
zhong[num]=zhong[num]+s[i]*p[i];
}
for(i=1;i<=n;i++)
{
wight=wight+s[i]*w[i];
}
if(wight<=c)
{
num=num+1;
}
else
{
zhong[num]=0;
}
return 0;
}
for(i=0;i<=1;i++)
{
s[tmp]=i;
f(tmp+1);
}
}
int max()
{
int i,j;
int flag=1;
for(i=1;i<=num;i++)
{
flag=1;
for(j=1;j<=num;j++)
{
if(zhong[i] < zhong[j])
{
flag=0;
}
}
if(flag == 1)
{
end[q]=zhong[i];
q=q+1;
}
}
return (0);
}
阅读全文
0 0
- 0-1背包 穷举版
- 0/1背包问题之穷举解法
- 0-1背包问题 穷举法
- 背包问题之穷举法
- 利用穷举法解决01背包问题
- 蓝桥杯1-穷举
- 穷举
- 穷举
- 穷举
- 穷举
- 穷举
- 背包问题(0-1背包、完全背包、多重背包)详解
- 0-1背包----完全背包
- 0-1背包+分数背包
- 0 1 背包 回溯版
- 0-1 背包 改良版
- 穷举法解决问题(1,2)
- 背包问题之0/1背包,完全背包,多重背包,混合背包
- 详解synchronized与Lock的区别与使用
- 坐标上升法算法
- java svg 转 png 学习
- 信贷风险指标你都懂吗?
- vue-router 2.0 跳转之router.push()
- 0-1背包 穷举版
- 看完让你彻底搞懂Websocket原理
- Spring Boot
- 运维之高级服务篇------ 4.Nginx常见问题处理、安装部署Tomcat服务器 、使用Tomcat部署虚拟主机
- Mobile_Detect.php:判断移动设备类型的开源PHP类使用说明
- 管理系统中的简单分区的一些知识
- 设置UIButton上的文字居左显示
- Intellij idea怎么将项目导出成war包
- plsql 11 注册码