力扣279. 完全平方数

Problem: 279. 完全平方数

文章目录

题目描述

思路及解法

1.定义一个int数组dp初始化长度为n+1;

2.状态初始化:当n等于0时,dp0为0;并且每次每次先初始化dpi = i,即表示为i时的最大所需完全平方根的个数为i个1

3.状态转移:假设当前的数为i,则第一步先从i往前找到一个 在数值上最接近i的完全平方数K,K的完全平方根为j(即K = j * j)则此时数值上还剩余i - j * j ,则第二步就是去在动态转移方程中查找i - j*j所需的最小完全平方根的个数再加上刚刚找到的一个数K;综上动态转移方程为:dpi = min(dpi, dpi - j \* j) + 1

复杂度

时间复杂度:

O ( n ⋅ n ) O(n \cdot \sqrt{n}) O(n⋅n );其中 n n n为给定的数;

空间复杂度:

O ( n ) O(n) O(n)

Code

java 复制代码
class Solution {
    /**
     * Return the least number of perfect square numbers that sum to n.
     *
     * @param n Given number
     * @return int
     */
    public int numSquares(int n) {
        int[] dp = new int[n + 1];
        for (int i = 1; i <= n; ++i) {
            dp[i] = i;
            for (int j = 1; i - j * j >= 0; ++j) {
                dp[i] = Math.min(dp[i], dp[i - j * j] + 1);
            }
        }
        return dp[n];
    }
}
相关推荐
猿人谷1 小时前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络2 小时前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络3 小时前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao4003 小时前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao4003 小时前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法
JieE2122 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack203 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树3 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2124 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法