贪心算法-分数背包问题

2024-08-22 14:52

本文主要是介绍贪心算法-分数背包问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

贪心算法与分数背包问题详解

目录

  • 贪心算法与分数背包问题详解
    • 贪心算法简介
    • 分数背包问题
      • 问题分析
      • 算法步骤
      • 流程图
      • 代码实现(C++)
      • 总结
    • C++学习资源

贪心算法简介

贪心算法是一种在每一步选择中都采取在当前状态下最好或最优的选择,从而希望导致结果是全局最好或最优的算法策略。它在有最优子结构的问题中尤为有效。

分数背包问题

与0-1背包问题不同,分数背包问题允许将物品的部分装入背包。这意味着我们可以将一个物品分割成任意大小,并根据其重量比例来计算其价值。

问题分析

  1. 单位价值:每个物品的单位价值是其价值与重量的比值,即val[i-1] / wgt[i-1]
  2. 贪心选择:按照单位价值从高到低对物品进行排序,然后依次考虑每个物品。

算法步骤

  1. 排序:将所有物品按照单位价值从高到低排序。
  2. 贪心循环:遍历排序后的物品列表,对于每个物品:
    • 如果物品重量小于等于剩余容量,将整个物品装入背包。
    • 如果物品重量大于剩余容量,只装入能够适应当前容量的部分。

流程图

物品重量小于等于容量
减少背包容量
物品重量大于容量
开始
初始化物品数组
对物品数组进行排序
初始化结果变量res
遍历排序后的物品数组
添加物品价值到res
继续遍历
计算剩余容量能装的价值
添加计算结果到res
结束遍历
返回最大价值res
结束

代码实现(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

这篇关于贪心算法-分数背包问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1096585

相关文章

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模