This commit is contained in:
youngyangyang04
2020-11-27 09:40:03 +08:00
parent 5a5e0a1944
commit 89a0e14743
6 changed files with 145 additions and 0 deletions

View File

@ -0,0 +1,58 @@
[1] 0 输出的是0不是-1啊这颗真是天坑j
```
// dp初始化很重要
class Solution {
public:
int coinChange(vector<int>& coins, int amount) {
//int dp[10003] = {0}; // 并没有给所有元素赋值0
if (amount == 0) return 0; // 这个要注意
vector<int> dp(10003, 0);
// 不能这么初始化啊,[2147483647]2 这种例子 直接gg但是这种初始化有助于理解
for (int i = 0; i < coins.size(); i++) {
if (coins[i] <= amount) // 还必须要加这个判断
dp[coins[i]] = 1;
}
for (int i = 1; i <= amount; i++) {
for (int j = 0; j < coins.size(); j++) {
if (i - coins[j] >= 0 && dp[i - coins[j]]!=0 ) {
if (dp[i] == 0) dp[i] = dp[i - coins[j]] + 1;
else dp[i] = min(dp[i - coins[j]] + 1, dp[i]);
}
}
//for (int k = 0 ; k<= amount; k++) {
// cout << dp[k] << " ";
//}
//cout << endl;
}
if (dp[amount] == 0) return -1;
return dp[amount];
}
};
```
这种标记d代码简短但思路有点绕
```
class Solution {
public:
int coinChange(vector<int>& coins, int amount) {
//int dp[10003] = {0}; // 并没有给所有元素赋值0
// if (amount == 0) return 0; 这个都可以省略了,但很多同学不知道 还需要注意这个
vector<int> dp(10003, 0);
for (int i = 1; i <= amount; i++) {
dp[i] = INT_MAX;
for (int j = 0; j < coins.size(); j++) {
if (i - coins[j] >= 0 && dp[i - coins[j]]!=INT_MAX ) {
dp[i] = min(dp[i - coins[j]] + 1, dp[i]);
}
}
}
if (dp[amount] == INT_MAX) return -1;
return dp[amount];
}
};
```

View File

@ -0,0 +1,22 @@
```
class Solution {
static bool cmp(int a, int b) {
return abs(a) < abs(b);
}
public:
int largestSumAfterKNegations(vector<int>& A, int K) {
sort(A.begin(), A.end(), cmp);
for (int i = A.size() - 1; i >= 0; i--) {
if (A[i] < 0 && K > 0) {
A[i] *= -1;
K--;
}
}
while (K--) A[0] *= -1;
int result = 0;
for (int a : A) result += a;
return result;
}
};
```

View File

@ -0,0 +1,19 @@
这是贪心啊LRLR 这本身就是平衡子串 , 但要LR这么分割这是贪心
```
class Solution {
public:
int balancedStringSplit(string s) {
int result = 0;
int count = 0;
for (int i = 0; i < s.size(); i++) {
if (s[i] == 'R') count++;
else count--;
if (count == 0) result++;
}
return result;
}
};
```

View File

@ -0,0 +1,25 @@
你说这是简单题吧,也是这就使用了贪心算法
```
class Solution {
private:
static bool cmp(int a, int b) {
return a > b;
}
public:
vector<int> minSubsequence(vector<int>& nums) {
sort(nums.begin(), nums.end(), cmp);
int sum = 0;
for (int i = 0; i < nums.size(); i++) sum += nums[i];
vector<int> result;
int resultSum = 0;
for (int i = 0; i < nums.size(); i++) {
resultSum += nums[i];
result.push_back(nums[i]);
if (resultSum > (sum - resultSum)) break;
}
return result;
}
};
```

View File

@ -0,0 +1,16 @@
```
// 这道题还是有陷阱啊15 4 这个例子答案应该是19 而不是18
class Solution {
public:
int numWaterBottles(int numBottles, int numExchange) {
int result = numBottles;
while (numBottles / numExchange) {
result += numBottles / numExchange;
// 所以不是 numBottles = (numBottles / numExchange)
numBottles = (numBottles / numExchange) + (numBottles % numExchange);
}
return result;
}
};
```