算法提高 貪吃的大嘴 時間限制: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); }}新聞熱點
疑難解答