C语言贪心算法书包问题,贪心算法背包有关问题(帮忙看看看)

C/C++ code#include

#include

#define N 50

int x,m;

void analyse(int n,int y,float weight[N],float price[N]) /* 将他们的价值进行排序*/

{

int i,j;

int flag; /*判断*/

float s[N],temp;

for(i=1;i <=n;i++) /* 改为for(i = 0;i < n;i++),不然越界*/

s[i]=price[i]/weight[i];

for(i=1;i <=n;i++) /* 改为for(i = 0;i < n;i++),不然越界*/

{

flag=0;

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

if(s[j]>s[j+1])

{

flag=1;

temp=s[j];

s[j]=s[j+1];

s[j+1]=temp;

temp=weight[j];

weight[j]=weight[j+1];

weight[j+1]=temp;

temp=price[j];

price[j]=price[j+1];

price[j+1]=temp;

}

if(!flag) break;

}

}

void input(int n,int y,float weight[N],float price[N]) /*输入数据*/

{ int k;

printf("输入物品种数:\n");

scanf("%d",&n);

printf("输入背包重量:\n");

scanf("%1f",&y); /*int y应该用%d*/

printf("输入%d个物品的重量:\n",n);

for(k=1;k <=n;k++) /* 改为for(k = 0;k < n;k++),不然越界*/

scanf("%1f",&weight[k]); /* %lf为double,float weight[]应该用%f */

printf("输入%d个物品的价值:\n",n);

for(k=1;k <=n;k++) /* 改为for(k = 0;k < n;k++),不然越界*/

scanf("%1f",&price[k]); /* %lf为double,float price[]应该用%f */

}

void find(int n,int y,float weight[N],float price[N]) /* 选择方案*/

{

int i;

float sum=0;

for(i=n;i>=1;i--) /* 改为for(i = (n - 1);i > 0;i--),不然越界*/

{

if(sum

{

if(weight[i] <=(y-sum))

{

sum=sum+weight[i];

printf("%d %d",&price[i],&weight[i]); /* %d 改为%f,不然输出的数据不正确 */

}

else

{

printf("%d %d",&price[i],&weight[i]); /* %d 改为%f,不然输出的数据不正确 */

break;

}

}

else

break;

}

}

int main()

{

float w[N],p[N];

input(x,m,w,p);

analyse(x,m,w,p);

find(x,m,w,p);

getch();

return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值