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

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

算法提高 貪吃的大嘴

2019-11-11 07:29:31
字體:
來源:轉載
供稿:網友

算法提高 貪吃的大嘴 時間限制: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); }}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 红原县| 长宁县| 新源县| 泗阳县| 平陆县| 三台县| 子洲县| 武山县| 昭苏县| 正定县| 锦屏县| 东阿县| 健康| 苍梧县| 新化县| 县级市| 禹州市| 鄢陵县| 庆城县| 南乐县| 乐至县| 霞浦县| 边坝县| 潜山县| 凤城市| 布尔津县| 西城区| 南靖县| 衡东县| 万山特区| 兰溪市| 枞阳县| 新乐市| 丹寨县| 永安市| 襄垣县| 桐柏县| 中牟县| 芦山县| 桐柏县| 杨浦区|