本文主要是介绍贪心算法-分数背包问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
贪心算法与分数背包问题详解
目录
- 贪心算法与分数背包问题详解
- 贪心算法简介
- 分数背包问题
- 问题分析
- 算法步骤
- 流程图
- 代码实现(C++)
- 总结
- C++学习资源
贪心算法简介
贪心算法是一种在每一步选择中都采取在当前状态下最好或最优的选择,从而希望导致结果是全局最好或最优的算法策略。它在有最优子结构的问题中尤为有效。
分数背包问题
与0-1背包问题不同,分数背包问题允许将物品的部分装入背包。这意味着我们可以将一个物品分割成任意大小,并根据其重量比例来计算其价值。
问题分析
- 单位价值:每个物品的单位价值是其价值与重量的比值,即
val[i-1] / wgt[i-1]
。 - 贪心选择:按照单位价值从高到低对物品进行排序,然后依次考虑每个物品。
算法步骤
- 排序:将所有物品按照单位价值从高到低排序。
- 贪心循环:遍历排序后的物品列表,对于每个物品:
- 如果物品重量小于等于剩余容量,将整个物品装入背包。
- 如果物品重量大于剩余容量,只装入能够适应当前容量的部分。
流程图
代码实现(C++)
#include <iostream>
#include <vector>
#include <algorithm>using namespace std;class Item {
public:int w; // 物品重量int v; // 物品价值Item(int w, int v) : w(w), v(v) {}
};bool compare(Item a, Item b) {return (double)a.v / a.w > (double)b.v / b.w;
}double greedyFractionBag(vector<int>& wgt, vector<int>& val, int cap) {vector<Item> items(wgt.size());for (int i = 0; i < wgt.size(); i++) {items[i] = Item(wgt[i], val[i]);}sort(items.begin(), items.end(), compare);double res = 0;for (auto& item : items) {if (item.w <= cap) {res += item.v;cap -= item.w;} else {res += (double)item.v / item.w * cap;break;}}return res;
}int main() {vector<int> w = {10, 20, 30, 40, 50};vector<int> v = {50, 120, 150, 210, 240};int c = 50;cout << "Maximum value: " << greedyFractionBag(w, v, c) << endl;return 0;
}
总结
贪心算法在解决分数背包问题时展示了其高效性。通过合理地排序和贪心选择,我们可以得到一个接近或达到最优解的方案。
C++学习资源
以下是我学习C++觉得不错的资料,仅供学习
:
匠心精作C++从0到1入门编程-学习编程不再难
链接: https://pan.baidu.com/s/1q7NG28V8IKMDGD7CMTn2Lg?pwd=ZYNB 提取码: ZYNB
第二套、侯捷老师全系列八部曲 - 手把手教你进阶系列
链接: https://pan.baidu.com/s/1AYzdguXzbaVZFw1tY6rYJQ?pwd=ZYNB 提取码: ZYNB
这篇关于贪心算法-分数背包问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!