代码随想录 第九章 动态规划part03 01背包问题 一维 416. 分割等和子集

01背包问题 一维

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main(){
    int n, bagWeight;
    cin >> n >> bagWeight;
    std::vector<int> value(n, 0);
    std::vector<int> weight(n, 0);
    for (int i = 0; i < n; i++) cin >> weight[i];
    for (int i = 0; i < n; i++) cin >> value[i];
    std::vector<int> result(bagWeight + 1, 0);
    for (int i = weight[0]; i<=bagWeight; i++) result[i] = value[0];
    for (int i = 1; i < n; i++){
        for (int j = bagWeight; j >= 0; j--){
            if (j >= weight[i]) result[j] = max(result[j], result[j - weight[i]] + value[i]);
        }
    }
    cout << result[bagWeight];
    return 0;
}

一维与二维的区别在于记录最优价值的数组是一维还是二维,从随想录所给的计算思路可以看出,在计算二维数组的过程中,只需要知道上一行的数据即可计算下一行的最优价值,所以完全可以只借助一个一维数组,不断迭代数组的值,求取最终的最优价值。

416. 分割等和子集

cpp 复制代码
class Solution {
public:
    bool canPartition(vector<int>& nums) {
        int sum=0;
        for (int i = 0; i < nums.size(); i++) sum += nums[i];
        if (sum % 2 != 0) return false;
        vector<int> value((sum / 2) + 1, 0);
        for (int i = nums[0]; i < value.size(); i++) value[i] = nums[0];
        for (int i = 1; i < nums.size(); i++){
            for (int j = sum / 2; j>=0; j--){
                if (j >= nums[i]) value[j] = max(value[j], value[j - nums[i]] + nums[i]);
            }
        }
        if (value[sum / 2] != sum / 2) return false;
        return true;
    }
};

这题乍一看首先想到的思路就是回溯,不过现在是动态规划了。如果将数字集合看做重量与价值相等的物品集合,如果集合能分为两个和相等的子集,在背包问题中也就意味着在背包最大容量为所有物品重量和的1/2时,最多能装下重量为所有物品和的1/2的物品,因为物品价值与重量相等,所以最优价值不会大于背包容量,但如果最终最优价值低于背包容量,也就代表数字集合无法被分为两个和相等的部分。

代码随想录 第九章 动态规划part03

相关推荐
luckys.one1 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
~|Bernard|2 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师2 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo32 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
好家伙VCC3 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
liulilittle5 小时前
IP校验和算法:从网络协议到SIMD深度优化
网络·c++·网络协议·tcp/ip·算法·ip·通信
bkspiderx6 小时前
C++经典的数据结构与算法之经典算法思想:贪心算法(Greedy)
数据结构·c++·算法·贪心算法
中华小当家呐8 小时前
算法之常见八大排序
数据结构·算法·排序算法
沐怡旸8 小时前
【算法--链表】114.二叉树展开为链表--通俗讲解
算法·面试
一只懒洋洋9 小时前
K-meas 聚类、KNN算法、决策树、随机森林
算法·决策树·聚类