给定一个只包含正整数的非空数组。是否可以将这个数组分割成两个子集,使得两个子集的元素和相等。
注意:
- 每个数组中的元素不会超过 100
- 数组的大小不会超过 200
class Solution {
public boolean canPartition(int[] nums) {
int len = nums.length;
if (len == 0) return false;
//得出数组总和
int sum = 0;
for (int num : nums) {
sum += num;
}
if (sum % 2 != 0) return false;
int target = sum / 2;
boolean[] dp = new boolean[target + 1];
dp[0] = true;
if (nums[0] <= target) {
dp[nums[0]] = true;
}
for (int i = 1; i < len; i++) {
for (int j = target; nums[i] <= j; j--) {
//剪枝
if (dp[target]) {
return true;
}
//一维逆序,是0-1背包,一维不逆序,是完全背包。
//因为j - nums[i],所以j才需要逆序
dp[j] = dp[j] || dp[j - nums[i]];
}
}
return dp[target];
}
}
因为昨天才开始接触动态规划,而且也不理解背包问题,所以理所当然,这道题不会,根据liweiwei1419
的题解一步一步做,一点一点的理解,现在还是似懂非懂,先把这道题丢进收藏夹里吃灰,回头再做。