auto commit

This commit is contained in:
CyC2018 2018-03-28 15:27:36 +08:00
parent 3f81fd96eb
commit 76933f018a
2 changed files with 20 additions and 12 deletions

View File

@ -1748,24 +1748,30 @@ public int integerBreak(int n) {
```java ```java
public int numSquares(int n) { public int numSquares(int n) {
List<Integer> squares = new ArrayList<>(); // 存储小于 n 的平方数 List<Integer> squareList = generateSquareList(n);
int diff = 3;
while(square <= n) {
squares.add(square);
square += diff;
diff += 2;
}
int[] dp = new int[n + 1]; int[] dp = new int[n + 1];
for(int i = 1; i <= n; i++) { for (int i = 1; i <= n; i++) {
int max = Integer.MAX_VALUE; int max = Integer.MAX_VALUE;
for(int s : squares) { for (int square : squareList) {
if(s > i) break; if (square > i) break;
max = Math.min(max, dp[i - s] + 1); max = Math.min(max, dp[i - square] + 1);
} }
dp[i] = max; dp[i] = max;
} }
return dp[n]; return dp[n];
} }
private List<Integer> generateSquareList(int n) {
List<Integer> squareList = new ArrayList<>();
int diff = 3;
int square = 1;
while (square <= n) {
squareList.add(square);
square += diff;
diff += 2;
}
return squareList;
}
``` ```
**分割整数构成字母字符串** **分割整数构成字母字符串**
@ -1798,7 +1804,9 @@ public int numDecodings(String s) {
[Leetcode : 62. Unique Paths (Medium)](https://leetcode.com/problems/unique-paths/description/) [Leetcode : 62. Unique Paths (Medium)](https://leetcode.com/problems/unique-paths/description/)
题目描述:统计从矩阵左上角到右下角的路径总数,每次只能向左和向下移动。 题目描述:统计从矩阵左上角到右下角的路径总数,每次只能向右或者向下移动。
<div align="center"> <img src="../pics//7c98e1b6-c446-4cde-8513-5c11b9f52aea.jpg"/> </div><br>
```java ```java
public int uniquePaths(int m, int n) { public int uniquePaths(int m, int n) {

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB