【代码随想录day 35】 力扣 416. 分割等和子集

视频讲解:https://www.bilibili.com/video/BV1rt4y1N7jE/?vd_source=a935eaede74a204ec74fd041b917810c

文档讲解:https://programmercarl.com/0416.分割等和子集.html#_01背包问题

力扣题目:https://leetcode.cn/problems/partition-equal-subset-sum/

这道题就是一个换皮的01背包,本质上是一样的,我们可以转换为是否可以装满一个sum / 2的背包,其中重量数组和价值数组都为nums[i].

cpp 复制代码
class Solution {
public:
    bool canPartition(vector<int>& nums) {
        //排序
        //sort(nums.begin(), nums.end());
        //计算sum
        int sum = 0;
        for(int i = 0; i < nums.size(); ++i)
        {
            sum += nums[i];
        }
        //剪枝,如果为奇数,直接返回false
        if(sum % 2 != 0)
        {
            return false;
        }

        //1.dp含义:dp[i][j]表示在0-i个数,容量为j中,能装的最大的数,如果等于sum/2则true
        vector<vector<int>> dp(nums.size(), vector<int>(sum / 2 + 1, 0));
        //2.递推公式:dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]);
        //3.初始化,最上一行和最左一列
        for(int i = 0; i < nums.size(); ++i)
        {
            dp[i][0] = 0;
        }
        for(int j = 0; j <= sum / 2; ++j)
        {
            //如果放得下
            if(j >= nums[0])
            {
                dp[0][j] = nums[0];
            }
        }
        //4.遍历方式,从上到下,从左到右
        for(int i = 1; i < nums.size(); ++i)
        {
            for(int j = 1; j <= sum / 2; ++j)
            {
                if(j < nums[i])
                {
                    dp[i][j] = dp[i - 1][j];
                }
                else
                {
                    dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - nums[i]] + nums[i]);
                }
                //cout << "dp[" << i << "][" << j << "]:" << dp[i][j] << endl;
            }
        }
        if(dp[nums.size() - 1][sum / 2] == sum / 2)
        {
            return true;
        }
        return false;
    }
};
相关推荐
.格子衫.44 分钟前
022数据结构之树状数组——算法备赛
数据结构·算法·1024程序员节
黑科技Python1 小时前
生活中的“小智慧”——认识算法
学习·算法·生活
sali-tec2 小时前
C# 基于halcon的视觉工作流-章52-生成标定板
开发语言·图像处理·人工智能·算法·计算机视觉
IT古董2 小时前
【第五章:计算机视觉-项目实战之推荐/广告系统】2.粗排算法-(4)粗排算法模型多目标算法(Multi Task Learning)及目标融合
人工智能·算法·1024程序员节
熬了夜的程序员2 小时前
【LeetCode】89. 格雷编码
算法·leetcode·链表·职场和发展·矩阵
對玛祷至昏3 小时前
数据结构理论知识
数据结构·算法·排序算法
oliveira-time3 小时前
二分搜索(Binary Search)
算法
王哈哈^_^3 小时前
【数据集】【YOLO】【目标检测】口罩数据集,口罩佩戴识别数据集 1971 张,YOLO佩戴口罩检测算法实战训练教程。
人工智能·算法·yolo·目标检测·计算机视觉·ai·视觉检测
程序员杰哥4 小时前
Pytest之收集用例规则与运行指定用例
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·pytest
dragoooon344 小时前
[优选算法专题四.前缀和——NO.31~32 连续数组、矩阵区域和]
数据结构·算法·leetcode·1024程序员节