算法系列--动态规划--背包问题(5)--二维费用背包问题(上)

简介: 算法系列--动态规划--背包问题(5)--二维费用背包问题(上)

💕"要平安无事地活下去."💕

作者:Lvzi

文章主要内容:算法系列–动态规划–背包问题(5)–二维费用背包问题

大家好,今天为大家带来的是算法系列--动态规划--背包问题(5)--二维费用背包问题

一.⼀和零

链接:

https://leetcode.cn/problems/ones-and-zeroes/

分析:

分析题目,题目要求的是满足条件的所有子集中,元素最多的一个,有两个限制条件:

  1. 子集中0的个数不能超过m
  2. 子集中1的个数不能超过n

如果对01背包问题敏感的话,立即就能发现这道题目和01背包问题很像,01背包问题的最大特征就是在所给定的限制条件下,可以实现的最大价值,在01背包问题模版那道题目中,需要满足的限制条件只有一个不超过最大的体积j,但是本题的限制条件有两个(可以理解为多了一个不超过最大重量的限制条件)

这种具有两个限制条件的背包问题我们称之为二维费用的背包问题,包含两种01背包问题和完全背包问题,本题由于可选的物品的数量是唯一的,所以是01背包问题

二位费用的01背包问题其实就是多了一种限制条件,我们只需将dp表设置为三维的即可,分析思路通普通的01背包问题

状态表示:

  • dp[i][j][k]:在在i个子集中选择,0的数目不超过j,1的数目不超过k,所有的选法中,子集中元素最多的

状态转移方程的分析同样的也是根据最后一个位置的状态去划分

初始化和填表顺序以及返回值和01背包问题一致

代码:

class Solution {
    public int findMaxForm(String[] strs, int m, int n) {
        int len = strs.length;
        int[][][] dp = new int[len + 1][m + 1][n + 1];
        for(int i = 1; i <= len; i++) {
            int a = 0, b = 0;
            for(char x : strs[i - 1].toCharArray()) {
                if(x == '0') a++;
                else b++;
            }
            for(int k = 0; k <= m; k++) {
                for(int j = 0; j <= n; j++) {
                    dp[i][k][j] = dp[i - 1][k][j];
                    if(k >= a && j >= b)
                        dp[i][k][j] = Math.max(dp[i][k][j],dp[i - 1][k - a][j - b] + 1);
                }
            }
        }
        return dp[len][m][n];
    }
}

同样的,二维费用的背包问题也可以进行空间优化,空间优化的方式和普通的01背包问题一致,分为两步:

  1. 去掉所有的横坐标
  2. 更改遍历顺序

空间优化版本:

class Solution {
    public int findMaxForm(String[] strs, int m, int n) {
        int len = strs.length;
        int[][] dp = new int[m + 1][n + 1];// 创建dp表
        for(int i = 1; i <= len; i++) {
            // 求出当前字符中0,1的个数
            int a = 0, b = 0;
            for(char x : strs[i - 1].toCharArray()) {
                if(x == '0') a++;
                else b++;
            }
            // 填表
            for(int k = m; k >= a; k--) {
                for(int j = n; j >= b; j--) {    
                    dp[k][j] = Math.max(dp[k][j],dp[k - a][j - b] + 1);
                }
            }
        }
        return dp[m][n];
    }
}

算法系列--动态规划--背包问题(5)--二维费用背包问题(下)https://developer.aliyun.com/article/1480866?spm=a2c6h.13148508.setting.14.352e4f0ecxYhMg

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

热门文章

最新文章