416-分割等和子集
题目链接:LeetCode-416中等
class Solution {
public:
bool canPartition(vector<int>& nums) {
int sum=0;
// dp[i]中的i表示背包内总和
vector<int> dp(10001,0);
for(int i=0;i<nums.size();i++){
sum+=nums[i];
}
if(sum%2==1) return false;
int target=sum/2;
for(int i=0;i<nums.size();i++){
for(int j=target;j>=nums[i];j--){
dp[j]=max(dp[j],dp[j-nums[i]]+nums[i]);
}
}
// 集合中的元素正好可以凑成总和target
if(dp[target]==target) return true;
return false;
}
};