力扣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];
    }
};
相关推荐
TracyCoder1238 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
u0109272719 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_941837269 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
六义义10 小时前
java基础十二
java·数据结构·算法
四维碎片10 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs10 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
独自破碎E11 小时前
【优先级队列】主持人调度(二)
算法
weixin_4454766811 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王11 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展
Swift社区12 小时前
LeetCode 385 迷你语法分析器
算法·leetcode·职场和发展