漫画:什么是“贪心算法”?如何求解“部分背包问题”?

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第1张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第2张图片

—————  第二天  —————

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第3张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第4张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第5张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第6张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第7张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第8张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第9张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第10张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第11张图片

————————————

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第12张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第13张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第14张图片

. . . . . . . .

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第15张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第16张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第17张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第18张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第19张图片

我们回到刚才的题目当中,假设背包的容量是10,有5个商品可供选择,每个商品的价值和重量如图所示:

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第20张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第21张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第22张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第23张图片

让我们来计算一下每件物品的性价比,其结果如下:

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第24张图片

毫无疑问,此时性价比最高的是物品4,我们把物品4放入背包当中,背包剩余的容量是8:

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第25张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第26张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第27张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第28张图片

我们选择物品1放入背包,背包剩余的容量是4:

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第29张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第30张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第31张图片

于是,我们选择0.8份的物品5放入背包,背包剩余的容量为0:

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第32张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第33张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第34张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第35张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第36张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第37张图片

public static void main(String[] args) {
        int capacity = 10;
        int[] weights = {4,6,3,2,5};
        int[] values = {9,3,1,6,5};
        System.out.println("背包最大价值:" + getHighestValue(capacity, weights, values));
    }

    public static double getHighestValue(int capacity, int[] weights,int[] values){

        //创建物品列表并按照性价比倒序
        List itemList = new ArrayList<>();
        for(int i=0;i

在这段代码当中,我们借助了静态内部类Item,从而更方便地记录性价比、获取重量和价值信息、按性价比排序。

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第38张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第39张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第40张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第41张图片

仍然给定一个容量是10的背包,有如下三个物品可供选择:

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第42张图片

这一次我们有个条件限制:只允许选择整个物品,不能选择物品的一部分。

如果按照贪心算法的思路,首先选择的是性价比最高的物品1,那么背包剩余容量是4,再也装不下其他物品,而此时的总价值是6:

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第43张图片

但这样的选择,真的能让总价值最大化吗?如果我们不选择物品1,选择物品2和物品3的话,剩余容量是0,总价值是7:

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第44张图片

显然,7>6,依靠贪心算法得出的结果,未必是全局最优解。

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第45张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第46张图片

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第47张图片

漫画:什么是动态规划?(整合版)

漫画:什么是“贪心算法”?如何求解“部分背包问题”?_第48张图片

你可能感兴趣的:(算法,贪心算法,动态规划,stream,java)