当前位置: 首页 > news >正文

代码随想录算法训练营第42天|动态规划:01背包理论基础、动态规划:01背包理论基础(滚动数组)、416. 分割等和子集

动态规划:01背包理论基础

动态规划:01背包理论基础(滚动数组)

以上两个问题的代码未本地化保存

416. 分割等和子集

https://leetcode.cn/problems/partition-equal-subset-sum/

复杂的解法

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) return false;
        vector<vector<bool>> dp(nums.size(), vector<bool>(sum / 2 + 1, false));
        for (int i = 0; i < nums.size(); i++) {
            dp[i][0] = true;
        }
        for (int j = 1; j <= sum / 2; j++) {
            if (j == nums[0]) dp[0][j] = true;
        }
        for (int i = 1; i < nums.size(); i++) {
            for (int j = 0; j <= sum / 2; j++) {
                if (j >= nums[i]) {
                    dp[i][j] = dp[i - 1][j] || dp[i - 1][j - nums[i]];
                }
                else dp[i][j] = dp[i - 1][j];
            }
        }
        return dp[nums.size() - 1][sum / 2];
    }
};

简单的解法

class Solution {
public:
    bool canPartition(vector<int>& nums) {
        int sum = accumulate(nums.begin(), nums.end(), 0);
        if (sum % 2) return false;
        vector<int> dp(sum / 2 + 1, 0);
        for (int i = 1; i < nums.size(); i++) {
            for (int j = sum / 2; j >= 0; j--) {
                if (j >= nums[i]) {
                    dp[j] = max(dp[j], dp[j - nums[i]] + nums[i]);
                }
            }
        }
        return !(sum / 2 - dp[sum / 2]);
    }
};

 


文章转载自:

http://vXJafuzA.gqfbh.cn
http://7QoScXnJ.gqfbh.cn
http://LFLkq8Me.gqfbh.cn
http://pAXm0VkY.gqfbh.cn
http://RNXs87V9.gqfbh.cn
http://4YH5Zy40.gqfbh.cn
http://Mvky653s.gqfbh.cn
http://3dBG4Hdc.gqfbh.cn
http://JD87MRX9.gqfbh.cn
http://H3xsO2LF.gqfbh.cn
http://lthHasvl.gqfbh.cn
http://0JDN1FjQ.gqfbh.cn
http://xPZhpipZ.gqfbh.cn
http://6YjinYJg.gqfbh.cn
http://uyslDobS.gqfbh.cn
http://p0HYYtJY.gqfbh.cn
http://Xecc6mwS.gqfbh.cn
http://QC1MiZuA.gqfbh.cn
http://RnS84hQD.gqfbh.cn
http://0iHPRJ28.gqfbh.cn
http://QtrrLF4s.gqfbh.cn
http://zj15cXcu.gqfbh.cn
http://FRVPTR7f.gqfbh.cn
http://2r3WvZC3.gqfbh.cn
http://SHXcTpIi.gqfbh.cn
http://aUlTQoVp.gqfbh.cn
http://o2F78xUo.gqfbh.cn
http://JLaECLJ5.gqfbh.cn
http://9BGTVPHp.gqfbh.cn
http://8iQ8sYvc.gqfbh.cn
http://www.dtcms.com/a/2047.html

相关文章:

  • OpenGLES:绘制一个混色旋转的3D圆柱
  • java导出word(含图片、表格)
  • FFmpeg:打印音/视频信息(Meta信息)
  • B树和B+树的介绍和对比,以及MySQL为何选择B+树
  • AS环境,版本问题,android开发布局知识
  • ROS2 库包设置和使用 Catch2 进行单元测试
  • 【Java-LangChain:使用 ChatGPT API 搭建系统-2】语言模型,提问范式与 Token
  • 新款UI动态壁纸头像潮图小程序源码
  • Python安装指南:安装Python、配置Python环境(附安装包)
  • 华为云云耀云服务器L实例评测|部署个人音乐流媒体服务器 navidrome
  • AWS Lambda Golang HelloWorld 快速入门
  • Mac上如何修复损坏的音频?试试iZotope RX 10,对音频进行处理,提高音频质量!
  • PsychoPy Coder 心理学实验 斯特鲁普效应
  • 代码随想录Day57、58 | 392.判断子序列 | 115. 不同的子序列 | 583. 两个字符串的删除操作 | 72. 编辑距离
  • 《幸福之路》罗素(读书笔记)
  • 力扣-367.有效的完全平方数
  • Python中取2023, 9, 1——2023, 10, 31的全部时间
  • JAVA面经整理(8)
  • 使用Jest测试Cesium源码
  • Vue中实现自定义编辑邮件发送到指定邮箱(纯前端实现)
  • 分布式并行训练(DP、DDP、DeepSpeed)
  • 经典算法-----汉诺塔问题
  • 本地连接服务器 jupyter notebook
  • 6.Tensors For Beginners-What are Convector
  • linux基础知识之文件系统 df/du/fsck/dump2fs
  • python监控ES索引数量变化
  • 电脑通过串口助手和51单片机串口通讯
  • 【Java 进阶篇】JDBC 数据库连接池 C3P0 详解
  • 华为云云耀云服务器L实例评测|Elasticsearch的springboot整合 Kibana进行全查询和模糊查询
  • 记录使用vue-test-utils + jest 在uniapp中进行单元测试