国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

算法提高 貪吃的大嘴

2019-11-11 07:00:59
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

算法提高 貪吃的大嘴 時(shí)間限制:1.0s 內(nèi)存限制:256.0MB 提交此題 問(wèn)題描述   有一只特別貪吃的大嘴,她很喜歡吃一種小蛋糕,而每一個(gè)小蛋糕有一個(gè)美味度,而大嘴是很傲嬌的,一定要吃美味度和剛好為m的小蛋糕,而且大嘴還特別懶,她希望通過(guò)吃數(shù)量最少的小蛋糕達(dá)到這個(gè)目的.所以她希望你能設(shè)計(jì)一個(gè)程序幫她決定要吃哪些小蛋糕. 輸入格式   先輸入一行包含2個(gè)整數(shù)m、n,表示大嘴需要吃美味度和為m的小蛋糕,而小蛋糕一共有n種,下面輸入n行,每行2個(gè)整數(shù),第一個(gè)表示該種小蛋糕的美味度,第二個(gè)表示蛋糕店中該種小蛋糕的總數(shù) 輸出格式   輸出一行包含一個(gè)整數(shù)表示大嘴最少需要吃的小蛋糕數(shù)量,若大嘴無(wú)法通過(guò)吃小蛋糕達(dá)到m的美味度和,則輸出”><“. 樣例輸入 10 2 4 1 2 10 樣例輸出 4 樣例輸入 10 2 4 1 7 3 樣例輸出

< 數(shù)據(jù)規(guī)模和約定   m ≤ 20000,小蛋糕總數(shù)量≤50.

簡(jiǎn)單背包

搜索直接超時(shí),但是m的數(shù)量為2w,n最大為50,所以最多運(yùn)算100w次 所以背包是很理想的算法選擇

#include <iostream>#include <cstring>#include <cstdio>#include <algorithm>#include <cmath>#include <map>using namespace std;int d[505];int dp[50000],tag[50000];int m,n,mins;const int mod=1000000;void bfs(int n){ memset(dp,1,sizeof(dp)); tag[0]=1; dp[0]=0; dp[m]=mod; for(int i=0;i<n;i++) { for(int j=m;j>=d[i];j--) { tag[j]=max(tag[j-d[i]],tag[j]); if(tag[j]) { dp[j]=min(dp[j],dp[j-d[i]]+1); } } } if(dp[m]!=mod) cout<<dp[m]<<endl; else cout<<"><"<<endl;}int main(){ while(cin>>m>>n) { mins=mod; int x, y,j=0,k; for(int i=0;i<n;i++) { cin>>x>>y;//蛋糕的種類(lèi)和美味度 for(k=j;k<j+y;k++)//把蛋糕排列出來(lái) { d[k]=x; } j=k; } // cout<<j<<endl; bfs(j); }}
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 兴宁市| 玛纳斯县| 若尔盖县| 姚安县| 宁化县| 榆林市| 白水县| 海盐县| 建瓯市| 开鲁县| 江陵县| 苏尼特左旗| 达尔| 高雄县| 钦州市| 平塘县| 疏附县| 宕昌县| 临湘市| 沈阳市| 远安县| 都江堰市| 错那县| 河曲县| 梧州市| 海南省| 黄陵县| 青海省| 福安市| 榆社县| 辽宁省| 台中市| 宝清县| 瑞丽市| 余江县| 岐山县| 容城县| 磐安县| 通辽市| 太仆寺旗| 彰武县|