分割等和子集
2022-03-31 本文已影响0人
xiaohei_e853
data:image/s3,"s3://crabby-images/acb35/acb35b1b1e186ad86400e0d4b19f04bcf3426356" alt=""
data:image/s3,"s3://crabby-images/dbae7/dbae788ef74e1d06095cc015d337d5cb75343fcc" alt=""
data:image/s3,"s3://crabby-images/20ad8/20ad86d30793e2925a985b73fdef97fe777e54d3" alt=""
data:image/s3,"s3://crabby-images/485ec/485ec9fb178ca21cb695a37851efad9d7aab56ae" alt=""
data:image/s3,"s3://crabby-images/9268e/9268e702e6b7d688aaad0476136eaf45869818f0" alt=""
data:image/s3,"s3://crabby-images/a1e68/a1e68ddc8c38ded48ffb9fdc43c40afa88002283" alt=""
第一版代码:
data:image/s3,"s3://crabby-images/736f6/736f676b9a40ec22ae3f299bb4fac8c61efbbfce" alt=""
data:image/s3,"s3://crabby-images/ed89a/ed89ae690c1942135843ed58b7f2d6e258b14078" alt=""
只用一维数组解决
data:image/s3,"s3://crabby-images/99789/9978954585319bd2f06b44d47990590c27004b8f" alt=""
public class CanPartion {
public static void main(String[] args) {
int[] nums = {1,5,11,5};
canPartion(nums);
}
public static boolean canPartion(int[] nums){
int sum = 0;
for (int i = 0; i < nums.length; i++) {
sum +=nums[i];
}
if(sum%2==1){
return false;
}
int target = sum/2;
boolean[] dp = new boolean[target+1];
dp[0] = true;
dp[nums[0]] = true;
for (int i = 0; i <nums.length ; i++) {
for (int j = target; j >0&&j>=nums[i] ; j--) {
int tmp = j-nums[i];
dp[j] = dp[j]||dp[j-nums[i]];
}
}
return dp[target];
}
}