mirror of
https://github.com/youngyangyang04/leetcode-master.git
synced 2025-07-13 06:06:11 +08:00
Update
This commit is contained in:
58
problems/0322.零钱兑换.md
Normal file
58
problems/0322.零钱兑换.md
Normal 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];
|
||||
}
|
||||
};
|
||||
```
|
22
problems/1005.K次取反后最大化的数组和.md
Normal file
22
problems/1005.K次取反后最大化的数组和.md
Normal 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;
|
||||
}
|
||||
};
|
||||
```
|
19
problems/1221.分割平衡字符串.md
Normal file
19
problems/1221.分割平衡字符串.md
Normal 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;
|
||||
}
|
||||
};
|
||||
```
|
25
problems/1403.非递增顺序的最小子序列.md
Normal file
25
problems/1403.非递增顺序的最小子序列.md
Normal 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;
|
||||
}
|
||||
};
|
||||
```
|
16
problems/1518.换酒问题.md
Normal file
16
problems/1518.换酒问题.md
Normal 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;
|
||||
}
|
||||
};
|
||||
```
|
Reference in New Issue
Block a user