1049.最后一块石头的重量
//每次取俩块石头进行碰撞,撞完后,剩下石头块,又可以与新取的石头进行碰撞。。。。
//不断进行反复,取舍
//类似与分割等和子集问题
class Solution {
public:
int lastStoneWeightII(vector<int>& stones) {
vector<int> dp(15001, 0);
int sum = 0;
for (int i = 0; i < stones.size(); i++) sum += stones[i];
int target = sum / 2;
for (int i = 0; i < stones.size(); i++) { // 遍历物品
for (int j = target; j >= stones[i]; j--) { // 遍历背包
dp[j] = max(dp[j], dp[j - stones[i]] + stones[i]);
}
}
return sum - dp[target] - dp[target];
}
};
这道题类似于,分割等和子集的题型,分割为俩个大小相近的背包