https://leetcode.com/problems/perfect-squares/
Given an integer n, return the least number of perfect square numbers that sum to n.
A perfect square is an integer that is the square of an integer; in other words, it is the product of some integer with itself. For example, 1, 4, 9, and 16 are perfect squares while 3 and 11 are not.
Example 1:
Input: n = 12 Output: 3 Explanation: 12 = 4 + 4 + 4.
Example 2:
Input: n = 13 Output: 2 Explanation: 13 = 4 + 9.
Constraints:
- 1 <= n <= 104
import java.util.*;
public class Solution {
public int numSquares(int n) {
int[] dp = new int[n+1];
Arrays.fill(dp, Integer.MAX_VALUE);
dp[0] = 0;
for (int i = 1; i <= n; i++){
for (int j = 1; j * j <= i; j++){
dp[i] = Math.min(dp[i - j * j] + 1, dp[i]);
}
}
return dp[n];
}
}
1. 어려웠던 점:
- DP는 늘 어렵다.
2. 알게된 점:
- DP의 유명한 방식? 이니까 다음에 다시 한 번 더 풀어서 확실히 익혀야겠다.
3. 알고리즘 풀이:
- dp 배열은 perfect square의 조합으로 만들 수 있는 최소의 수 배열이다.
dp[0]은 0의 최소 조합이므로, 당연히 0
이 후, 그 자신보다 같거나 작은 perfect square의 dp값을 타고가
전부 비교해, 가장 작은 값을 계산하는 방식이다.
'알고리즘 문제풀이 > LeetCode' 카테고리의 다른 글
[LeetCode 17] Letter Combinations of a Phone Number with JAVA (0) | 2021.05.27 |
---|---|
[LeetCode 22] Generate Parentheses with Java (0) | 2021.05.26 |
[LeetCode 746] Min Cost Climbing Stairs with Java (0) | 2021.05.15 |
[LeetCode 91] Decode Ways with JAVA (0) | 2021.05.12 |
[LeetCode 53] Maximum Subarray with JAVA (0) | 2021.05.11 |