【力扣hot100】 416. 分割等和子集

一、题目

复制代码
给你一个 只包含正整数 的 非空 数组 nums 。
请你判断是否可以将这个数组分割成两个子集,使得两个子集的元素和相等。
 

示例 1:
输入:nums = [1,5,11,5]
输出:true
解释:数组可以分割成 [1, 5, 5] 和 [11] 。

示例 2:
输入:nums = [1,2,3,5]
输出:false
解释:数组不能分割成两个元素和相等的子集。
 

提示:
1 <= nums.length <= 200
1 <= nums[i] <= 100

二、思路

一开始没啥头绪,后面想着滑动窗口。

因为子集等和,所以只要找到一个子集等于数组和的一半即可。

于是想着排序后,右边去增加cur,左边减小cur来找数组的一半。但还是不行,无法跳过中间下标的数字...

问了下gpt,果然还是动态规划。

其实算是经典了,记得之前也做到过类似的,怎么这次又想不起来这个方法了呢。

就是外层遍历数组中的数字,内层遍历寻找的数字,从而得到该数字能否得到,并循环递推。

三、尝试

通过的测试用例:97 / 147 个

cpp 复制代码
class Solution {
public:
    bool canPartition(vector<int>& nums) {
        sort(nums.begin(),nums.end());
        int sum=0;
        for(auto t:nums){
            sum+=t;
        }
        if(sum%2!=0) return false;
        int left=0,right=0;
        int cur=0;
        bool found=false;
        while(right<nums.size()){
            if(cur<sum/2){
                cur+=nums[right];
                right++;
                if(found) return false;
            }
            if(cur>sum/2){
                cur-=nums[left];
                left++;
                found=true;
            }
            if(cur==sum/2) return true;
        }
        return false;
    }
};

四、题解

cpp 复制代码
class Solution {
public:
    bool canPartition(vector<int>& nums) {
        int sum=0;
        for(auto t:nums){
            sum+=t;
        }
        if(sum%2!=0) return false;
        vector<bool> dp(sum/2+1,false);
        dp[0]=true;
        for(int i=0;i<nums.size();i++){
            for(int j=sum/2;j>=nums[i];j--){
                dp[j]=dp[j]||dp[j-nums[i]];
            }
        }
        return dp[sum/2];
    }
};
相关推荐
ECT-OS-JiuHuaShan2 小时前
朱梁整体论,万有代谢元,矛盾因果网,人间正道是沧桑
人工智能·科技·算法·机器学习·拓扑学
qeen872 小时前
【算法笔记】二分查找与二分答案
c语言·c++·笔记·学习·算法·二分
C雨后彩虹2 小时前
投篮大赛问题
java·数据结构·算法·华为·面试
Sylvia-girl2 小时前
类与对象(下)
c++·友元函数·类与对象
Hello eveybody2 小时前
介绍最大公因数和最小公约数(C++)
java·开发语言·c++
橘白3162 小时前
GVHMR
人工智能·算法·机器人·机器人数据·视频动捕
宵时待雨2 小时前
优选算法专题3:二分查找
数据结构·c++·算法·leetcode·职场和发展
Byte不洛2 小时前
理解C++异常机制:栈展开、异常传播与异常安全
c++·异常处理·后端开发·编程基础·try catch
代码飞一会儿2 小时前
算法与数据结构之树——让数据查找更加迅速
算法