题目链接:279. 完全平方数 - 力扣(LeetCode)
完全平方数是可以表示成某个整数的平方的数,要找和为n的完全平方数的最少数目
满足要求的完全平方数最小是1,最大不会超过n的平方根
所以题目变成要从1,2,3,……,n的平方根中找出平方和的和是n的组合,并且数量最少
完全背包问题,同【LeetCode热题100】【动态规划】零钱兑换-CSDN博客
定义dp[i]为和为i的完全平方数的最少数目
class Solution {
public:int numSquares(int n) {vector<int> dp(n + 1,INT_MAX / 2);dp[0] = 0;for (int i = 0; i <= sqrt(n); ++i)for (int j = i * i; j <= n; ++j)dp[j] = min(dp[j], dp[j - i * i] + 1);return dp[n];}
};