算法系列--动态规划--背包问题(3)--完全背包介绍(下)

简介: 算法系列--动态规划--背包问题(3)--完全背包介绍(下)

算法系列--动态规划--背包问题(3)--完全背包介绍(上)

https://developer.aliyun.com/article/1480854?spm=a2c6h.13148508.setting.14.5f4e4f0ewTpliD

💕"Su7"💕

作者:Lvzi

文章主要内容:算法系列–动态规划–背包问题(3)–完全背包介绍

大家好,今天为大家带来的是算法系列--动态规划--背包问题(3)--完全背包介绍

代码:

import java.util.Scanner;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        // 1.解决第一问
        Scanner in = new Scanner(System.in);
        int n = in.nextInt(), V = in.nextInt();// 获取物品数目和体积
        int[] v = new int[n + 1], w = new int[n + 1];
        for(int i = 1; i <= n; i++) {
            v[i] = in.nextInt();// 物品体积
            w[i] = in.nextInt();// 物品价值
        }
        int[][] dp = new int[n + 1][V + 1];
        for(int i = 1; i <= n; i++) {
            for(int j = 1; j <= V; j++) {
                dp[i][j] = dp[i-1][j];
                if(j - v[i] >= 0)
                    dp[i][j] = Math.max(dp[i][j],dp[i][j - v[i]] + w[i]);
            }
        }
        System.out.println(dp[n][V]);
        // 1.解决第二问
        dp = new int[n + 1][ V + 1];// 好的代码风格?
        for(int j = 1; j <= V; j++) dp[0][j] = -1;
        for(int i = 1; i <= n; i++) {
            for(int j = 1; j <= V; j++) {
                dp[i][j] = dp[i - 1][j];
                if(j - v[i] >= 0 && dp[i][j - v[i]] != -1)
                    dp[i][j] = Math.max(dp[i][j],dp[i][j - v[i]] + w[i]);
            }
        }
        System.out.println(dp[n][V] == -1 ? 0 : dp[n][V]);
    }
}

空间优化:

同样的在完全背包问题中也可以进行空间优化(想想01背包问题中的空间优化,通过明确遍历顺序,只是用一个简单的线性数组就可以完成填表)

01背包问题的空间优化最需要注意的就是遍历顺序的改变,在01背包问题中,为了在填表的时候需要使用的数据不被覆盖掉,需要从右往左遍历,但是在完全背包问题中,需要从左往右遍历

空间优化后的代码:

import java.util.Scanner;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        // 1.解决第一问
        Scanner in = new Scanner(System.in);
        int n = in.nextInt(), V = in.nextInt();// 获取物品数目和体积
        int[] v = new int[n + 1], w = new int[n + 1];
        for(int i = 1; i <= n; i++) {
            v[i] = in.nextInt();// 物品体积
            w[i] = in.nextInt();// 物品价值
        }
        int[] dp = new int[V + 1];
        for(int i = 1; i <= n; i++)
            for(int j = v[i]; j <= V; j++)
                dp[j] = Math.max(dp[j],dp[j - v[i]] + w[i]);
        System.out.println(dp[V]);
        // 2.解决第二问
        dp = new int[ V + 1];// 好的代码风格?
        for(int j = 1; j <= V; j++) dp[j] = -1;
        for(int i = 1; i <= n; i++)
            for(int j = v[i]; j <= V; j++)
                if(dp[j - v[i]] != -1)
                    dp[j] = Math.max(dp[j],dp[j - v[i]] + w[i]);
            
        System.out.println(dp[V] == -1 ? 0 : dp[V]);
    }
}

以上就是算法系列--动态规划--背包问题(3)--完全背包介绍全部内容,下一篇文章将会带来完全背包问题的拓展题目,敬请期待,我是LvZi


目录
相关文章
|
21天前
|
机器学习/深度学习 存储 算法
动态规划算法深度解析:0-1背包问题
0-1背包问题是经典的组合优化问题,目标是在给定物品重量和价值及背包容量限制下,选取物品使得总价值最大化且每个物品仅能被选一次。该问题通常采用动态规划方法解决,通过构建二维状态表dp[i][j]记录前i个物品在容量j时的最大价值,利用状态转移方程避免重复计算子问题,从而高效求解最优解。
244 1
|
21天前
|
算法 搜索推荐 Java
贪心算法:部分背包问题深度解析
该Java代码基于贪心算法求解分数背包问题,通过按单位价值降序排序,优先装入高价值物品,并支持部分装入。核心包括冒泡排序优化、分阶段装入策略及精度控制,体现贪心选择性质,适用于可分割资源的最优化场景。
148 1
贪心算法:部分背包问题深度解析
|
8月前
|
存储 算法 Java
算法系列之动态规划
动态规划(Dynamic Programming,简称DP)是一种用于解决复杂问题的算法设计技术。它通过将问题分解为更小的子问题,并存储这些子问题的解来避免重复计算,从而提高算法的效率。
269 4
算法系列之动态规划
|
9月前
|
算法 Java C++
【潜意识Java】蓝桥杯算法有关的动态规划求解背包问题
本文介绍了经典的0/1背包问题及其动态规划解法。
225 5
|
8月前
|
算法 安全 调度
【动态规划篇】穿越算法迷雾:约瑟夫环问题的奇幻密码
【动态规划篇】穿越算法迷雾:约瑟夫环问题的奇幻密码
|
8月前
|
机器学习/深度学习 算法 测试技术
【动态规划篇】01 背包的逆袭:如何用算法装满你的 “财富背包”
【动态规划篇】01 背包的逆袭:如何用算法装满你的 “财富背包”
|
11月前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
207 2
|
12月前
|
算法
动态规划算法学习四:最大上升子序列问题(LIS:Longest Increasing Subsequence)
这篇文章介绍了动态规划算法中解决最大上升子序列问题(LIS)的方法,包括问题的描述、动态规划的步骤、状态表示、递推方程、计算最优值以及优化方法,如非动态规划的二分法。
212 0
动态规划算法学习四:最大上升子序列问题(LIS:Longest Increasing Subsequence)
|
13天前
|
存储 编解码 算法
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
|
15天前
|
传感器 机器学习/深度学习 算法
【使用 DSP 滤波器加速速度和位移】使用信号处理算法过滤加速度数据并将其转换为速度和位移研究(Matlab代码实现)
【使用 DSP 滤波器加速速度和位移】使用信号处理算法过滤加速度数据并将其转换为速度和位移研究(Matlab代码实现)
103 1

热门文章

最新文章