[面试算法] 01背包 & 完全背包
2017-04-30 10:23
309 查看
Discription
小Ho现在手上有M张奖券,而奖品区有N件奖品,分别标号为1到N,其中第i件奖品需要need(i)张奖券进行兑换,同时也只能兑换一次,为了使得辛苦得到的奖券不白白浪费,小Ho给每件奖品都评了分,其中第i件奖品的评分值为value(i),表示他对这件奖品的喜好值。现在他想知道,凭借他手上的这些奖券,可以换到哪些奖品,使得这些奖品的喜好值之和能够最大。每组测试数据的第一行为两个正整数N和M,表示奖品的个数,以及小Ho手中的奖券数。接下来的n行描述每一行描述一个奖品,其中第i行为两个整数need(i)和value(i),意义如前文所述。Solution
int main() { int N, M; cin >> N >> M; int x, y; vector<int> need, value; for (int i = 0; i < N; i++){ cin >> x >> y; need.push_back(x); value.push_back(y); } vector<int> dp(M+1,0); for (int i = 0; i <N; i++){ for (int j = M; j>need[i]; j--){ dp[j] = max(dp[j], dp[j - need[i]] + value[i]); } } cout << dp[M] << endl; cin.get(); cin.get(); return 0; }
Discription
每个奖品可以兑换无数次Solution
int main() { int N, M; cin >> N >> M; int x, y; vector<int> need, value; for (int i = 0; i < N; i++){ cin >> x >> y; need.push_back(x); value.push_back(y); } vector<int> dp(M+1,0); for (int i = 0; i <N; i++){ for (int j = 0; j<=M; j++){ if (need[i] <= j){ dp[j] = max(dp[j], dp[j - need[i]] + value[i]); } } } cout << dp[M] << endl; cin.get(); cin.get(); return 0; }GitHub-Leetcode:https://github.com/wenwu313/LeetCode
相关文章推荐
- 算法->完全背包问题 UVa 674 Coin Change
- 最新的一个面试的算法题目——一个完全背包问题
- 【算法学习笔记】30.动态规划 01背包和完全背包的关系
- hdu1114 & poj1384 完全背包
- 【ZOJ3587】Marlon's String——白四爷×KMP 白濑肆の算法完全解读KMP篇 KMP来袭第二弹前缀什么的果然最讨厌了!【1.0%达成!】
- 01背包、完全背包、多重背包详解
- hdu1147-完全背包&&hdu2191-多重背包
- 背包问题——01背包、完全背包、多重背包、混合三种背包问题
- 背包九讲之二 P02: 完全背包问题
- 动态规划-----背包问题-----01背包,完全背包,多重背包
- 一些算法(最短路,线段树,01,完全背包,STL)的基本参考资料
- 【HDU 1114 & POJ 1384】 完全背包(注意技巧)
- "2个面试华为光网测试的有关算法题",我写的程序!!!
- HDU 1059 01背包+完全背包=多重背包
- HDU 1059 01背包+完全背包=多重背包
- 背包问题(01背包和完全背包)
- 01背包,完全背包, 多重背包
- 相亲数&完全数最简单算法
- http://acm.hdu.edu.cn/showproblem.php?pid=2159&&二维完全背包
- 五只猴子分桃,算法&面试