【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];
    }
};
相关推荐
小王努力学编程1 小时前
高并发内存池(二):项目的整体框架以及Thread_Cache的结构设计
开发语言·c++·学习·算法
补三补四2 小时前
遗传算法(GA)
人工智能·算法·机器学习·启发式算法
dot to one2 小时前
C++ 渗透 数据结构中的二叉搜索树
数据结构·c++·算法·visual studio
好易学·数据结构3 小时前
可视化图解算法36: 序列化二叉树-I(二叉树序列化与反序列化)
数据结构·算法·leetcode·二叉树·力扣·序列化·牛客
_AaRong_3 小时前
经典密码学算法实现
算法·密码学
孙同学_4 小时前
【递归,搜索与回溯算法篇】专题(一) - 递归
算法·leetcode
Tummer83635 小时前
C语言与C++的区别
c语言·c++·算法
MSTcheng.5 小时前
【数据结构】算法的复杂度
数据结构·算法
了不起的杰6 小时前
【算法】:滑动窗口
算法
2301_807611496 小时前
47. 全排列 II
c++·算法·leetcode·回溯