思路:
转化为01背包,背包容量为sun/2
class Solution {
public:
bool canPartition(vector<int>& nums) {
int sum=0;
vector<int>dp(20000,0);
for(int& i:nums){
sum+=i;
}
if(sum%2==1) return false;
int bagsize=sum/2;
for(int i=0;i<nums.size();i++){
for(int j=bagsize;j>=nums[i];j--){
dp[j]=max(dp[j],dp[j-nums[i]]+nums[i]);
}
}
if(dp[bagsize]==bagsize) return true;
return false;
}
};