代码随想录算法训练营第四十四天 | 复习

复习:

1049. 最后一块石头的重量 II

class Solution {
public:
    int lastStoneWeightII(vector& stones) {
        // 目标重量 sum/2
        int sum = 0;
        for(int stone:stones) {
            sum += stone;
        }
        // 目标 dp[target] - 背包的重量
        int target = sum/2;
        vector dp(15001, 0);
        for(int i=0; i=stones[i]; --j) {
                // 这块石头放和不放
                dp[j] = max(dp[j], dp[j-stones[i]]+stones[i]);
            }
        }
        return sum-dp[target]-dp[target];
    }
};

494. 目标和

class Solution {
public:
    int findTargetSumWays(vector& nums, int target) {
        int sum = 0;
        for(int num:nums) {
            sum += num;
        }
        if(abs(target)>sum) return false;
        if((target+sum)%2!=0) return false;

        int left = (target+sum)/2;
        vector dp(left+1, 0);
        dp[0] = 1;

        for(int i=0; i=nums[i]; --j) {
                dp[j] += dp[j-nums[i]];
            }
        }
        return dp[left];
    }
};

你可能感兴趣的:(算法,c++,开发语言)