贪心算法-分数背包问题

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

目录

贪心算法简介

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

分数背包问题

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

问题分析

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

算法步骤

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

流程图

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

代码实现(C++)

cpp 复制代码
#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

相关推荐
weixin_3077791314 分钟前
软件演示环境动态扩展与成本优化:基于目标跟踪与计划扩展的AWS Auto Scaling策略
算法·云原生·云计算·aws
Carl_奕然15 分钟前
【机器视觉】一文掌握常见图像增强算法。
人工智能·opencv·算法·计算机视觉
放羊郎15 分钟前
人工智能算法优化YOLO的目标检测能力
人工智能·算法·yolo·视觉slam·建图
Lucis__44 分钟前
STL设计模式探秘:容器适配器&仿函数
c++·容器·stl·仿函数
无敌最俊朗@1 小时前
友元的作用与边界
算法
无敌最俊朗@1 小时前
C++ 对象布局之padding(填充字节)
开发语言·c++
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 104: 通配符匹配
linux·数据结构·算法·leetcode·深度优先·动态规划
小龙报1 小时前
《DevC++支持C++11等与其软件分辨率低的解决办法》
c语言·c++·windows·蓝桥杯·pat考试·学习方法·dvc++
程序员东岸1 小时前
从零开始学二叉树(上):树的初识 —— 从文件系统到树的基本概念
数据结构·经验分享·笔记·学习·算法
大佬,救命!!!2 小时前
C++函数式策略模式中配置修改
c++·学习笔记·迭代加深·企业级·函数式策略模式·多文件编译环境·json环境配置修改