c语言背包问题求找零钱问题和背包贪心算法问题(背包里物体可分解)C语言程序
c语言背包问题 时间:2021-07-03 阅读:(
)
编程序解决0 1 背包问题?(c语言)
for (int i=1;i<=n;i++)
for (int j=0;j<=v;j++)
if (j<w[i]) f[i][j]=f[i-1][j];
else f[i][j]=max(f[i-1][j],f[i-1][j-w[i]]+c[i]);//w为重量,c为价值,n为物品个数,v为背包容量
printf ("%d",f[n][v]);用C语言编写动态规划解决0-1背包问题,如何实现从.txt文件中读取数据
?程序要求
?动态规划的过程必须通过DProcessing( wi , vi , m[i,j] ) 计算
?wi表示物品 i的重量,
?vi 代表物品 i的价值,
?m[ i,j ] 代表当前正在规划的重量为 j 的背包 的价值
?注:动态规划的过程禁止直接写在主函数中!背包问题
容量为多少啊,楼主
本程序以背包容量为5为例(用C语言编写):
#define N 4 /*物品个数*/
#define W 5/*背包容量*/
#include <stdio.h>
/*******************************************************************
*************以下为动态规划算法解0-1背包问题****************/
int min(int a,int b)
{
return (a<b) ? a : b;
}
float max(float a,float b)
{
return (a>b) ? a : b;
}
void Knap(float*v,int *w,int c,float m[N+1][W+1])
{
int i,j;
int jMax=min(w[N]-1,c);
for(j=0;j<=jMax;j++) m[N][j]=0;
for(j=w[N];j<=c;j++) m[N][j]=v[N];
for(i=N-1;i>1;i--)
{
jMax=min(w[i]-1,c);
for(j=0;j<=jMax;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]);
}
m[1][c]=m[2][c];
if(c>=w[1]) m[1][c]=max(m[1][c],m[2][c-w[1]]+v[1]);
}
void Traceback(float m[N+1][W+1],int *w,int c,int *x)
{
int i;
for(i=1;i<N;i++)
if(m[i][c]==m[i+1][c]) x[i]=0;
else {x[i]=1; c-=w[i];}
x[N]=( (m[N][c]) ? 1 : 0 );
}
void Knapsack_1(float*v,int *w,int c,float m[N+1][W+1],int *x)
{
Knap(v,w, c,m);
Traceback(m,w,c,x);
}
/*******************************************************************
*****************以下为贪心算法解背包问题*********************/
void sort(float *v,float *w)
{
int i,j;
float temp;
for(i=1;i<N;i++)
for(j=i+1;j<=N;j++)
if(v[i]/w[i]<v[j]/w[j])
{
temp=v[i]; v[i]=v[j]; v[j]=temp;
temp=w[i]; w[i]=w[j]; w[j]=temp;
}
}
void Knapsack_2(float c,float *v,float *w,float *y)
{
int i;
sort(v,w);
for(i=1;i<=N;i++) y[i]=0;
for(i=1;i<=N;i++)
{
if(w[i]>c) break;
y[i]=1;
c-=w[i];
}
if(i<=N)
y[i]=c/w[i];
}
/*******************************************************************
*************************以下为主函数***************************/
main()
{
float m[N+1][W+1] , v[N+1]={N,1,2,2,1} , w_2[N+1]={N,2,1,2,3} , c_2=W;/*v[]存储价值,w[]存储质量,c为背包容量*/
int w_1[N+1]={N,2,1,2,3},c_1=W;
float y[N+1];
int x[N+1];
int i,j;
float vSum=0,wSum=0;
Knapsack_1(v,w_1,c_1,m,x);
printf("利用线性规划算法后,背包中的物品价值和质量为:
");
j=0;
for(i=1;i<=N;i++)
if(x[i])
{
printf("物品%d的价值为%g、质量为%d
",++j,v[i],w_1[i]);
vSum+=v[i]; wSum+=w_1[i];
}
printf("背包中总价值为%g、总质量为%g、背包剩余容量为%g
",vSum,wSum,c_1-wSum);
Knapsack_2(c_2,v,w_2,y);
vSum=wSum=0;
j=0;
printf("
利用贪心算法后,背包中的物品价值和质量为:
");
for(i=1;i<=N;i++)
if(y[i])
{
printf("物品%d的价值为%g、质量为%g
",++j,v[i]*y[i],w_2[i]*y[i]);
vSum+=v[i]*y[i]; wSum+=w_2[i]*y[i];
}
printf("背包中总价值为%g、总质量为%g、背包剩余容量为%g
",vSum,wSum,c_2-wSum);
printf("
注:两个算法得出的结果不一定相同,这是正常的。
");
}求计算背包问题总方案数的C语言程序或者思路啊!!!!!
#include<stdio.h>
#define N 100
int str[N];
int w[N];
int k=0;
void
backtrack(int i,int n,int m)
{
if(m==0){
k++;
for(int i=1;i<=n;i++)
if(str[i]!=i)
printf("%d ",i);
printf("
");
}
if(i<=n&&m>0){
for(int j=0;j*w[i]<=m;j++){
if(j!=0)str[i]=0;
backtrack(i+1,n,m-j*w[i]);
str[i]=i;
}
}
}
int
main()
{
int m,n;
printf("请输入背包的容积:
");
scanf("%d",&m);
printf("请输入物品的种类数:
");
scanf("%d",&n);
for(int i=1;i<=n;i++)
str[i]=i;
for(i=1;i<=n;i++){
printf("请输入第%d种物品的体积:
",i);
scanf("%d",&w[i]);
}
printf("背包中存放的物品的几种情况分别为为:
");//注意输出结果有的相同,但他们的数目不同
backtrack(1,n,m);
printf("总方案数为:%d
",k);
return 0;
}C语言的背包问题
1 在代码风格上不要把 for 循环以外的东西放到 for 语句内部,
2 i++ 建议使用++i
3 代码逻辑 除了 max 最清晰 其他的基本一眼 看不懂你想干嘛,你是写给你自己看的,就不要贴到网上让别人看了.求找零钱问题和背包贪心算法问题(背包里物体可分解)C语言程序
分数太少了,第一个是动态规划,第二个是贪心,都挺简单的
还是给你写吧
第一题:
#include<stdio.h>
#include<memory.h>
int a[2000],b[200000],n,m,i,j;
int main()
{
scanf("%d",&n);//钱币种类
for (i=0;i<n;i++)
scanf("%d",&a[i]);//每个钱币的面值
scanf("%d",&m);//需要计算的钱币的面值
memset(b,0,sizeof(b));
for (i=0;i<n;i++)
b[a[i]]=1;
for (i=1;i<=m;i++)
for (j=0;j<n;j++)
if (i-a[j]>0)
if (b[i]==0)
{
if (b[i-a[j]]!=0)
b[i]=b[i-a[j]]+1;
}
else
{
if (b[i-a[j]]!=0&&b[i-a[j]]+1<b[i])
b[i]=b[i-a[j]]+1;
}
if (b[m]==0) printf("-1
");//找不开输出-1
else printf("%d
",b[m]);//可以找到交换策略,输出最小票数
return 0;
}
第二题:
#include<iostream>
#include<algorithm>
using namespace std;
struct good//表示物品的结构体
{
double p;//价值
double w;//重量
double r;//价值与重量的比
}a[2000];
double s,value,m;
int i,n;
bool bigger(good a,good b)
{
return a.r>b.r;
}
int main()
{
scanf("%d",&n);//物品个数
for (i=0;i<n;i++)
{
scanf("%lf%lf",&a[i].w,&a[i].p);
a[i].r=a[i].p/a[i].w;
}
sort(a,a+n,bigger);//调用sort排序函数,你大概不介意吧,按照价值与重量比排序贪心
scanf("%lf",&m);//读入包的容量m
s=0;//包内现存货品的重量
value=0;//包内现存货品总价值
for (i=0;i<n&&s+a[i].w<=m;i++)
{
value+=a[i].p;
s+=a[i].w;
}
printf("The total value in the bag is %.2lf.
",value);//输出结果
return 0;
}
轻云互联成立于2018年的国人商家,广州轻云互联网络科技有限公司旗下品牌,主要从事VPS、虚拟主机等云计算产品业务,适合建站、新手上车的值得选择,香港三网直连(电信CN2GIA联通移动CN2直连);美国圣何塞(回程三网CN2GIA)线路,所有产品均采用KVM虚拟技术架构,高效售后保障,稳定多年,高性能可用,网络优质,为您的业务保驾护航。官方网站:点击进入广州轻云网络科技有限公司活动规则:用户购买任...
艾云怎么样?艾云是一家去年年底成立的国人主机商家,商家主要销售基于KVM虚拟架构的VPS服务,机房目前有美国洛杉矶、圣何塞和英国伦敦,目前商家推出了一些年付特价套餐,性价比非常高,洛杉矶套餐低至85元每年,给500M带宽,可解奈飞,另外圣何塞也有特价机器;1核/1G/20G SSD/3T/2.5Gbps,有需要的朋友以入手。点击进入:艾云官方网站艾云vps促销套餐:KVM虚拟架构,自带20G的防御...
搬瓦工怎么样?这几天收到搬瓦工发来的邮件,告知香港pccw机房(HKHK_1)即将关闭,这也不算是什么出乎意料的事情,反而他不关闭我倒觉得奇怪。因为目前搬瓦工香港cn2 GIA 机房和香港pccw机房价格、配置都一样,可以互相迁移,但是不管是速度还是延迟还是丢包率,搬瓦工香港PCCW机房都比不上香港cn2 gia 机房,所以不知道香港 PCCW 机房存在还有什么意义?关闭也是理所当然的事情。点击进...
c语言背包问题为你推荐
元数据管理什么是元数据?(指数据中心建设而言)举个例子说明一下。图片地址怎么获得图片地址oracle索引什么是Oracle的函数索引?arc是什么意思arctanx等于什么?丁奇海贼王里“D”的意思是什么?radius认证电信或网通的RADIUS认证都记录些什么?谁能说说ISP的宽带帐号检查流程欢迎页面怎样取消“欢迎页面”?faq是什么意思在国际贸易中“FAQ”代表的是什么意思问卷星登陆你好,如果之前用微信登录了问卷星小程序,以后每次回答都不需要微信登录了吗?回答了会被知道个人信息吗pci数据捕获和信号处理控制器华硕pci数据捕获和信号处理控制器出现黄色叹号该下载什么驱动
如何申请免费域名 私人服务器 56折 大容量存储 域名转接 佛山高防服务器 服务器托管什么意思 稳定免费空间 免费mysql数据库 域名与空间 学生服务器 ncp weblogic部署 asp简介 德国代理ip 免费服务器 vpsaa 免费php空间申请 电脑主机 主机响 更多