力扣279. 完全平方数

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量 。完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,14916 都是完全平方数,而 311 不是。

示例 1:

输入:n =12 输出:3

解释:12 = 4 + 4 + 4

示例 2:

输入:n =13 输出:2

解释:13 = 4 + 9

动态规划:

cpp 复制代码
class Solution {
public:
    int numSquares(int n) {
        //dp[n]=min(dp[n],dp[n-j*j]+1)

        vector<int> dp(n+1,INT_MAX);
        dp[0]=0;//必须初始化,否则在计算dp[4]=dp[4-2*2]+1时就会越界
        dp[1]=1;
        for(int i=2;i<n+1;i++){//遍历从1-n(背包)
            for(int j=1;i-j*j>=0;j++){//遍历完全平方数(物品)
                dp[i]=min(dp[i],dp[i-j*j]+1);
            }
            //printf("dp[%d]=%d\n",i,dp[i]);//打印dp数组
        }
        return dp[n];
    }
};
相关推荐
一招定胜负17 小时前
逻辑回归核心原理与实践指南
算法·逻辑回归·线性回归
长安er17 小时前
LeetCode 98. 验证二叉搜索树 解题总结
java·数据结构·算法·leetcode·二叉树·力扣
薛不痒17 小时前
机器学习算法之线性回归&逻辑回归
算法·机器学习·逻辑回归
sin_hielo17 小时前
leetcode 3433
数据结构·算法·leetcode
Swift社区17 小时前
LeetCode 448 - 找到所有数组中消失的数字
算法·leetcode·职场和发展
OKkankan17 小时前
二叉搜索树
c语言·数据结构·c++·算法
茶猫_18 小时前
C++学习记录-旧题新做-字符串压缩
c语言·c++·学习·算法·leetcode
拉姆哥的小屋18 小时前
从原子到性能:机器学习如何重塑双金属催化剂的设计范式
人工智能·python·算法·机器学习
leoufung18 小时前
LeetCode 162:寻找峰值的二分搜索思想与区间不变式分析
算法·leetcode·职场和发展
Non importa18 小时前
用滑动窗口代替暴力枚举:算法新手的第二道砍
java·数据结构·c++·学习·算法·leetcode·哈希算法