https://leetcode-cn.com/problems/partition-equal-subset-sum/
这个其实是0/1背包。观察能力捉急。。
要把数组分成相同的两部分。每部分则一定为数组和sum/2 。所以数组和sum一定为偶数。所以就是0/1背包。。。
class Solution {
public:
bool canPartition(vector<int>& nums) {
const int sum = accumulate(nums.begin(), nums.end(), 0);
if(sum & 1) return false;
int target = sum / 2;
int dp[sum + 1];
memset(dp, 0, sizeof dp);
dp[0] = 1;
for(int num : nums)
{
for(int i = sum; i >= 0; i--)
{
if(dp[i]) dp[i + num] = 1;
}
if(dp[target]) return true;
}
return false;
}
};