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

首頁 > 學院 > 開發設計 > 正文

算法提高 貪吃的大嘴

2019-11-11 06:19:01
字體:
來源:轉載
供稿:網友

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

< 數據規模和約定   m ≤ 20000,小蛋糕總數量≤50.

簡單背包

搜索直接超時,但是m的數量為2w,n最大為50,所以最多運算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;//蛋糕的種類和美味度 for(k=j;k<j+y;k++)//把蛋糕排列出來 { d[k]=x; } j=k; } // cout<<j<<endl; bfs(j); }}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 灌南县| 孙吴县| 盘锦市| 通江县| 稻城县| 遵化市| 苍溪县| 哈尔滨市| 蒙城县| 邮箱| 兴安盟| 广南县| 吴堡县| 香格里拉县| 田林县| 天全县| 禹城市| 铁岭市| 巫山县| 衢州市| 泰州市| 叙永县| 灵石县| 南郑县| 曲阳县| 临清市| 寿光市| 武宣县| 印江| 手游| 富顺县| 汤原县| 临湘市| 潮安县| 西平县| 哈尔滨市| 蒲江县| 屏山县| 敖汉旗| 建阳市| 华容县|