Given a positive integer n, find the least number of perfect square numbers (for example, 1, 4, 9, 16, ...
) which sum to n.
For example, given n = 12
, return 3
because 12 = 4 + 4 + 4
; given n = 13
, return 2
because 13 = 4 + 9
.
Credits:
Special thanks to @jianchao.li.fighter for adding this problem and creating all test cases.
思路:
dp,设dp[i]为和i的最少完全平方数。
dp[i] = min(dp[i] ,dp[i – j*j] + 1) {j *j <i}
int numSquares(int n) { vector<int>dp(n + 1); for (int i = 0; i <= n;i++) { dp[i] = i; for (int j = 1; j*j <= i;j++) { dp[i] = min(dp[i], dp[i - j*j] + 1); } } return dp[n]; }
参考: