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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

采药问题 c语言程序,采药 (C语言代码)

發(fā)布時間:2023/12/20 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 采药问题 c语言程序,采药 (C语言代码) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

解題思路:這個題充分考察了算法的能力,實(shí)際上就是01背包的一個非常簡單的變形,如果可以我建議先百度一下01背包,再來看這個問題就會容易的多了。

運(yùn)用到的知識:

多維數(shù)組,遞歸(知道為什么不好做了吧( ̄▽ ̄)"

注意事項:一定要注意數(shù)組的范圍!!!題主就是在這個非常平常的地方栽了跟頭。。。哭4

參考代碼:

int max(int a,int b)

{

return a>b?a:b;

}

int main()

{

int T,M,t[101],c[101];? //t[101]儲存每一個藥的時間,c[101]儲存每一個藥價值

int f[102][1002]={0};? //務(wù)必初始化,其實(shí)呢也可以只用把二維數(shù)組的第一行初始化就ok了

int i,j,k;

scanf("%d %d",&T,&M);

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

{

scanf("%d %d",&t[i],&c[i]);

}

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

{

for(j=1;j<=T;j++)

{

if(j>=t[i])

f[i][j]=max(f[i-1][j],f[i-1][j-t[i]]+c[i]);? //這就是01背包中的兩個狀態(tài),采或者不采兩種情況哪個的價值最大

else

f[i][j]=f[i-1][j]; ?? //書包的空間(時間不夠了)

}

}

for(i=0;i<=M;i++)????????????//檢查所有的值,找最大的值

{

k=f[0][0];

for(j=0;j<=T;j++)

{

if(f[i][j]>k)

k=f[i][j];

}

}

printf("%d",k);

}

//其實(shí)呢,除了多維數(shù)組,一維數(shù)組利用遞歸也是可以解決問題滴

//不過,悲慘的超時了。。。。

int t[100],c[100];

int main()

{

int T,M,k,i;

scanf("%d %d",&T,&M);

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

{

scanf("%d %d",&t[i],&c[i]);

}

int make(int ,int );

k=make(M,T);

printf("%d",k);

return 0;

}

int make(int i,int j)? ??//第 i個對象,剩余j個時間

{

if(i==0)

return 0;

if(j>=t[i])

{

int r1=make(i-1,j);

int r2=make(i-1,j-t[i])+c[i];

return r1>r2?r1:r2;

}

else return make(i-1,j);

}

總結(jié)

以上是生活随笔為你收集整理的采药问题 c语言程序,采药 (C语言代码)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。