力扣——完全平方数

题目链接:

链接

题目描述:

思路:

用动态规划,设 i i i的最少数量是 d p ( i ) dp(i) dp(i),最多数量是 i i i,如1+1+...+1

则 d p ( i ) = m i n { i , d p ( i − j ∗ j ) + 1 } dp(i)=min\{ i,dp(i-j*j)+1 \} dp(i)=min{i,dp(i−j∗j)+1}

这里为什么是 d p ( i − j ∗ j ) + 1 dp(i-j*j)+1 dp(i−j∗j)+1,因为要得到 i i i减去一个平方数后的最小组成数量,那么 i i i的最小组成数量就是减去平方数后的最小组成数量+1,这个1就代表减去的这个平方数

实现代码:

java 复制代码
class Solution {
    public int numSquares(int n) {
        int[] dp = new int[n+1];
        dp[0] = 0;
        for(int i = 1; i <= n; i++){
            int minn = i;
            for(int j = 1; i - j * j >=0; j++){
                minn = Math.min(minn, dp[i - j * j] + 1);
            }
            dp[i] = minn;
        }
        return dp[n];
    }
}
相关推荐
05候补工程师几秒前
【408考研复习】数据结构核心笔记:字符串模式匹配与内部排序算法全解析
数据结构·经验分享·笔记·考研·算法·排序算法
阿文的代码库4 分钟前
浅谈:无向图的欧拉回路
算法
-Thinker5 分钟前
AI 算法核心原理与实现
人工智能·算法·机器学习
Eloudy7 分钟前
最小权重完美匹配(MWPM)与表面码纠错
算法·量子计算
-森屿安年-8 分钟前
62. 不同路径
算法·动态规划
学计算机的计算基20 分钟前
Codex CLI vs Claude Code 全方位对比:设计哲学与用户体验深度解析
算法
欧阳x天26 分钟前
八大排序算法(C语言实现)
数据结构·算法·排序算法
爱睡懒觉的焦糖玛奇朵28 分钟前
【从视频到数据集:焦糖玛奇朵的魔法工具Dataset Cleaner】
人工智能·python·学习·算法·yolo·音视频
xjxijd30 分钟前
行为感知算法赋能运维,提前预判硬件故障与异常访问
运维·算法
江屿风32 分钟前
C++图论基础拓扑排序经典OJ题流食般投喂
开发语言·c++·笔记·算法·图论