【LeetCode热题100】【动态规划】完全平方数

题目链接: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];
    }
};
相关推荐
你怎么知道我是队长4 分钟前
C语言---排序算法4---希尔排序法
c语言·算法·排序算法
iAkuya9 分钟前
(leetcode)力扣100 54实现Trie树
算法·leetcode·c#
TracyCoder12325 分钟前
LeetCode Hot100(20/100)——19. 删除链表的倒数第 N 个结点
算法·leetcode
hrrrrb28 分钟前
【算法设计与分析】随机化算法
人工智能·python·算法
进击的小头35 分钟前
一阶IIR低通滤波器:从原理到嵌入式实战
c语言·算法
2301_811232981 小时前
C++中的契约编程
开发语言·c++·算法
2401_829004021 小时前
C++中的访问者模式
开发语言·c++·算法
青槿吖1 小时前
第二篇:JDBC进阶骚操作:防注入、事务回滚、连接池优化,一篇封神
java·开发语言·jvm·算法·自动化
sin_hielo1 小时前
leetcode 1984
数据结构·算法·leetcode