日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發布時間:2023/12/20 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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;

}

總結

以上是生活随笔為你收集整理的C语言贪心算法书包问题,贪心算法背包有关问题(帮忙看看看)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。