auto commit
This commit is contained in:
parent
7591a398df
commit
769ed707d9
|
@ -2327,15 +2327,17 @@ Note that different sequences are counted as different combinations.
|
||||||
Therefore the output is 7.
|
Therefore the output is 7.
|
||||||
```
|
```
|
||||||
|
|
||||||
|
完全背包。
|
||||||
|
|
||||||
```java
|
```java
|
||||||
public int combinationSum4(int[] nums, int target) {
|
public int combinationSum4(int[] nums, int target) {
|
||||||
if (nums == null || nums.length == 0) return 0;
|
if (nums == null || nums.length == 0) return 0;
|
||||||
int[] dp = new int[target + 1];
|
int[] dp = new int[target + 1];
|
||||||
dp[0] = 1;
|
dp[0] = 1;
|
||||||
for (int i = 1; i <= target; i++) {
|
for (int i = 1; i <= target; i++) {
|
||||||
for (int j = 0; j < nums.length; j++) {
|
for (int num : nums) {
|
||||||
if (nums[j] <= i) {
|
if (num <= i) {
|
||||||
dp[i] += dp[i - nums[j]];
|
dp[i] += dp[i - num];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2343,30 +2345,13 @@ public int combinationSum4(int[] nums, int target) {
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
**只能进行两次的股票交易**
|
|
||||||
|
|
||||||
[Leetcode : 123. Best Time to Buy and Sell Stock III (Hard)](https://leetcode.com/problems/best-time-to-buy-and-sell-stock-iii/description/)
|
|
||||||
|
|
||||||
```java
|
|
||||||
public int maxProfit(int[] prices) {
|
|
||||||
int firstBuy = Integer.MIN_VALUE, firstSell = 0;
|
|
||||||
int secondBuy = Integer.MIN_VALUE, secondSell = 0;
|
|
||||||
for (int curPrice : prices) {
|
|
||||||
if (firstBuy < -curPrice) firstBuy = -curPrice;
|
|
||||||
if (firstSell < firstBuy + curPrice) firstSell = firstBuy + curPrice;
|
|
||||||
if (secondBuy < firstSell - curPrice) secondBuy = firstSell - curPrice;
|
|
||||||
if (secondSell < secondBuy + curPrice) secondSell = secondBuy + curPrice;
|
|
||||||
}
|
|
||||||
return secondSell;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
**只能进行 k 次的股票交易**
|
**只能进行 k 次的股票交易**
|
||||||
|
|
||||||
[Leetcode : 188. Best Time to Buy and Sell Stock IV (Hard)](https://leetcode.com/problems/best-time-to-buy-and-sell-stock-iv/description/)
|
[Leetcode : 188. Best Time to Buy and Sell Stock IV (Hard)](https://leetcode.com/problems/best-time-to-buy-and-sell-stock-iv/description/)
|
||||||
|
|
||||||
```html
|
```html
|
||||||
dp[i, j] = max(dp[i, j-1], prices[j] - prices[jj] + dp[i-1, jj]) { jj in range of [0, j-1] } = max(dp[i, j-1], prices[j] + max(dp[i-1, jj] - prices[jj]))
|
dp[i, j] = max(dp[i, j-1], prices[j] - prices[jj] + dp[i-1, jj]) { jj in range of [0, j-1] }
|
||||||
|
= max(dp[i, j-1], prices[j] + max(dp[i-1, jj] - prices[jj]))
|
||||||
```
|
```
|
||||||
|
|
||||||
```java
|
```java
|
||||||
|
@ -2392,6 +2377,24 @@ public int maxProfit(int k, int[] prices) {
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
**只能进行两次的股票交易**
|
||||||
|
|
||||||
|
[Leetcode : 123. Best Time to Buy and Sell Stock III (Hard)](https://leetcode.com/problems/best-time-to-buy-and-sell-stock-iii/description/)
|
||||||
|
|
||||||
|
```java
|
||||||
|
public int maxProfit(int[] prices) {
|
||||||
|
int firstBuy = Integer.MIN_VALUE, firstSell = 0;
|
||||||
|
int secondBuy = Integer.MIN_VALUE, secondSell = 0;
|
||||||
|
for (int curPrice : prices) {
|
||||||
|
if (firstBuy < -curPrice) firstBuy = -curPrice;
|
||||||
|
if (firstSell < firstBuy + curPrice) firstSell = firstBuy + curPrice;
|
||||||
|
if (secondBuy < firstSell - curPrice) secondBuy = firstSell - curPrice;
|
||||||
|
if (secondSell < secondBuy + curPrice) secondSell = secondBuy + curPrice;
|
||||||
|
}
|
||||||
|
return secondSell;
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
### 数组区间
|
### 数组区间
|
||||||
|
|
||||||
**数组区间和**
|
**数组区间和**
|
||||||
|
@ -2824,8 +2827,7 @@ public int countPrimes(int n) {
|
||||||
|
|
||||||
```java
|
```java
|
||||||
int gcd(int a, int b) {
|
int gcd(int a, int b) {
|
||||||
if (b == 0) return a;
|
return b == 0 ? a : gcd(b, a% b);
|
||||||
return gcd(b, a % b);
|
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -2841,47 +2843,80 @@ int lcm(int a, int b){
|
||||||
|
|
||||||
对于 a 和 b 的最大公约数 f(a, b),有:
|
对于 a 和 b 的最大公约数 f(a, b),有:
|
||||||
|
|
||||||
1\. 如果 a 和 b 均为偶数,f(a, b) = 2\*f(a/2, b/2);
|
- 如果 a 和 b 均为偶数,f(a, b) = 2\*f(a/2, b/2);
|
||||||
2\. 如果 a 是偶数 b 是奇数,f(a, b) = f(a/2, b);
|
- 如果 a 是偶数 b 是奇数,f(a, b) = f(a/2, b);
|
||||||
3\. 如果 b 是偶数 a 是奇数,f(a, b) = f(a, b/2);
|
- 如果 b 是偶数 a 是奇数,f(a, b) = f(a, b/2);
|
||||||
4\. 如果 a 和 b 均为奇数,f(a, b) = f(a, a-b);
|
- 如果 a 和 b 均为奇数,f(a, b) = f(a, a-b);
|
||||||
|
|
||||||
乘 2 和除 2 都可以转换为移位操作。
|
乘 2 和除 2 都可以转换为移位操作。
|
||||||
|
|
||||||
### 进制转换
|
### 进制转换
|
||||||
|
|
||||||
Java 中 static String toString(int num, int radix) 可以将一个整数装换为 redix 进制表示的字符串。
|
|
||||||
|
|
||||||
**7 进制**
|
**7 进制**
|
||||||
|
|
||||||
[Leetcode : 504. Base 7 (Easy)](https://leetcode.com/problems/base-7/description/)
|
[Leetcode : 504. Base 7 (Easy)](https://leetcode.com/problems/base-7/description/)
|
||||||
|
|
||||||
```java
|
```java
|
||||||
public String convertToBase7(int num) {
|
public String convertToBase7(int num) {
|
||||||
if (num < 0) {
|
if (num < 0) return '-' + convertToBase7(-num);
|
||||||
return '-' + convertToBase7(-num);
|
if (num < 7) return num + "";
|
||||||
}
|
|
||||||
if (num < 7) {
|
|
||||||
return num + "";
|
|
||||||
}
|
|
||||||
return convertToBase7(num / 7) + num % 7;
|
return convertToBase7(num / 7) + num % 7;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
```java
|
||||||
|
public String convertToBase7(int num) {
|
||||||
|
if (num == 0) return "0";
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
boolean isNegative = num < 0;
|
||||||
|
if (isNegative) num = -num;
|
||||||
|
while (num > 0) {
|
||||||
|
sb.append(num % 7);
|
||||||
|
num /= 7;
|
||||||
|
}
|
||||||
|
String ret = sb.reverse().toString();
|
||||||
|
return isNegative ? "-" + ret : ret;
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Java 中 static String toString(int num, int radix) 可以将一个整数转换为 redix 进制表示的字符串。
|
||||||
|
|
||||||
|
```java
|
||||||
|
public String convertToBase7(int num) {
|
||||||
|
return Integer.toString(num, 7);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
**16 进制**
|
**16 进制**
|
||||||
|
|
||||||
[Leetcode : 405. Convert a Number to Hexadecimal (Easy)](https://leetcode.com/problems/convert-a-number-to-hexadecimal/description/)
|
[Leetcode : 405. Convert a Number to Hexadecimal (Easy)](https://leetcode.com/problems/convert-a-number-to-hexadecimal/description/)
|
||||||
|
|
||||||
|
负数要用它的补码形式。
|
||||||
|
|
||||||
|
```html
|
||||||
|
Input:
|
||||||
|
26
|
||||||
|
|
||||||
|
Output:
|
||||||
|
"1a"
|
||||||
|
|
||||||
|
Input:
|
||||||
|
-1
|
||||||
|
|
||||||
|
Output:
|
||||||
|
"ffffffff"
|
||||||
|
```
|
||||||
|
|
||||||
```java
|
```java
|
||||||
public String toHex(int num) {
|
public String toHex(int num) {
|
||||||
char[] map = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
|
char[] map = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
|
||||||
if(num == 0) return "0";
|
if(num == 0) return "0";
|
||||||
String ret = "";
|
StringBuilder sb = new StringBuilder();
|
||||||
while(num != 0){
|
while(num != 0){
|
||||||
ret = map[(num & 0b1111)] + ret;
|
sb.append(map[num & 0b1111]);
|
||||||
num >>>= 4;
|
num >>>= 4; // 无符号右移,左边填 0
|
||||||
}
|
}
|
||||||
return ret;
|
return sb.reverse().toString();
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -2918,15 +2953,14 @@ Return "100".
|
||||||
```java
|
```java
|
||||||
public String addBinary(String a, String b) {
|
public String addBinary(String a, String b) {
|
||||||
int i = a.length() - 1, j = b.length() - 1, carry = 0;
|
int i = a.length() - 1, j = b.length() - 1, carry = 0;
|
||||||
String str = "";
|
StringBuilder str = new StringBuilder();
|
||||||
while(i >= 0 || j >= 0){
|
while (carry == 1 || i >= 0 || j >= 0) {
|
||||||
if (i >= 0 && a.charAt(i--) == '1') carry++;
|
if (i >= 0 && a.charAt(i--) == '1') carry++;
|
||||||
if (j >= 0 && b.charAt(j--) == '1') carry++;
|
if (j >= 0 && b.charAt(j--) == '1') carry++;
|
||||||
str = (carry % 2) + str;
|
str.append(carry % 2);
|
||||||
carry /= 2;
|
carry /= 2;
|
||||||
}
|
}
|
||||||
if(carry == 1) str = "1" + str;
|
return str.reverse().toString();
|
||||||
return str;
|
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -2938,15 +2972,15 @@ public String addBinary(String a, String b) {
|
||||||
|
|
||||||
```java
|
```java
|
||||||
public String addStrings(String num1, String num2) {
|
public String addStrings(String num1, String num2) {
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder str = new StringBuilder();
|
||||||
int carry = 0;
|
int carry = 0, i = num1.length() - 1, j = num2.length() - 1;
|
||||||
for(int i = num1.length() - 1, j = num2.length() - 1; i >= 0 || j >= 0 || carry == 1; i--, j--){
|
while (carry == 1 || i >= 0 || j >= 0) {
|
||||||
int x = i < 0 ? 0 : num1.charAt(i) - '0';
|
int x = i < 0 ? 0 : num1.charAt(i--) - '0';
|
||||||
int y = j < 0 ? 0 : num2.charAt(j) - '0';
|
int y = j < 0 ? 0 : num2.charAt(j--) - '0';
|
||||||
sb.append((x + y + carry) % 10);
|
str.append((x + y + carry) % 10);
|
||||||
carry = (x + y + carry) / 10;
|
carry = (x + y + carry) / 10;
|
||||||
}
|
}
|
||||||
return sb.reverse().toString();
|
return str.reverse().toString();
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user