class Solution {
public:
int lastStoneWeightII(vector<int>& stones) {
vector<int> dp(1501, 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];
}
};
class Solution {
public:
int findMaxForm(vector<string>& strs, int m, int n) {
//最多有m个0, n个1
vector<vector<int>> dp(m+1, vector<int>(n+1, 0));
for(string str : strs) {
int x = 0, y = 0;
for (char c : str) {
//统计0和1的数量
if (c == '0') x++;
else y++;
}
for (int i = m; i >= x; i--) { // 0
for (int j = n; j >= y; j--) {// 1
dp[i][j] = max (dp[i][j], dp[i-x][j-y] + 1);
}
}
}
return dp[m][n];
}
};