【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];
    }
};
相关推荐
点云SLAM3 小时前
PyTorch 中.backward() 详解使用
人工智能·pytorch·python·深度学习·算法·机器学习·机器人
only-qi3 小时前
146. LRU 缓存
java·算法·缓存
梁辰兴5 小时前
数据结构:排序
数据结构·算法·排序算法·c·插入排序·排序·交换排序
Lris-KK5 小时前
【Leetcode】高频SQL基础题--1731.每位经理的下属员工数量
sql·leetcode
野犬寒鸦5 小时前
力扣hot100:搜索二维矩阵 II(常见误区与高效解法详解)(240)
java·数据结构·算法·leetcode·面试
菜鸟得菜5 小时前
leecode kadane算法 解决数组中子数组的最大和,以及环形数组连续子数组的最大和问题
数据结构·算法·leetcode
楼田莉子6 小时前
C++算法专题学习——分治
数据结构·c++·学习·算法·leetcode·排序算法
一支鱼6 小时前
leetcode常用解题方案总结
前端·算法·leetcode
ulias2126 小时前
各种背包问题简述
数据结构·c++·算法·动态规划
m0_570466417 小时前
代码随想录算法训练营第二十八天 | 买卖股票的最佳实际、跳跃游戏、K次取反后最大化的数组和
java·开发语言·算法