【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];
    }
};
相关推荐
编程绿豆侠9 分钟前
力扣HOT100之二分查找: 34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
Shan120517 分钟前
找到每一个单词+模拟的思路和算法
数据结构·算法
国家不保护废物24 分钟前
微信红包算法深度解析:从产品思维到代码实现
javascript·算法·面试
小明同学0141 分钟前
[C++入门]简化的艺术---对模版的初步探索
开发语言·c++·算法
kaiaaaa2 小时前
算法训练第八天
算法
LL_xjbt2 小时前
代码随想录刷题day29
算法·leetcode·动态规划
叶子2024222 小时前
守护进程实验——autoDL
人工智能·算法·机器学习
半桔2 小时前
【算法深练】分组循环:“分”出条理,化繁为简
数据结构·c++·算法·leetcode·面试·职场和发展
天天爱吃肉82182 小时前
【十年技术演进深度解构:车载充电机(OBC)将成为新能源汽车的“能源大脑”】
python·嵌入式硬件·算法·汽车·能源
KerwinChou_CN3 小时前
自由开发者计划 004:创建一个苹果手机长截屏小程序
图像处理·算法·智能手机·小程序