力扣第84题:完全平方数

第一部分:问题描述

给你一个整数 n ,返回 n完全平方数最少数量** 。

完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,14916 都是完全平方数,而 311 不是。

示例 1:

复制代码
输入:n = 12

输出:3 
解释:12 = 4 + 4 + 4

示例 2:

复制代码
输入:n = 13

输出:2
解释:13 = 4 + 9

第二部分:代码实现

(1)核心思想

①定义 dp[i]:表示和为 i 的完全平方数的最少数量

②状态转移:要得到 i,可以从 i - k² 加一个完全平方数 得到,所以:

因为 k 可以取很多值(1, 2, 3...),每种取值都会得到一个方案数:

  • dp[12-1] + 1 = dp[11] + 1
  • dp[12-4] + 1 = dp[8] + 1
  • dp[12-9] + 1 = dp[3] + 1

我们要从这些方案中选出数量最少 的那个,所以外面套了一个 min()

③边界条件:dp[0] = 0(和为 0 需要 0 个平方数)。

(2)完整提交代码

复制代码
class Solution:
    def numSquares(self, n: int) -> int:
        #初始化dp数组,dp[i]初始化为最坏情况(全用1的平方,总共i个)
        dp=[i for i in range(n+1)]#写到n+1是因为一会要用到dp[n]
        for i in range(1,n+1):
            #遍历所有小于等于i的平方数
            for k in range(1,int(math.sqrt(i)+1)):#sqrt是根号的意思
                square=k*k
                dp[i]=min(dp[i],dp[i-square]+1)
        return dp[n]

代码解析:

  • 初始化dp = [i for i in range(n + 1)]
    • 最坏情况:每个数都由 i 组成,所以 dp[i] = i
  • 外层循环 :遍历 1n,计算每个数的最小平方数数量。
  • 内层循环 :遍历所有小于等于 i 的平方数 ,更新 dp[i]
    • dp[i] = min(dp[i], dp[i - square] + 1):比较当前值和「用 加上 i - square 的最小数量」哪个更小。
  • 返回结果dp[n] 就是和为 n 的最少完全平方数数量。
相关推荐
菜菜的顾清寒14 小时前
力扣HOT100(50)动态规划-零钱兑换
算法·leetcode·动态规划
周末也要写八哥14 小时前
三分钟读懂:如何解决做题数量不足的问题?
算法
8Qi814 小时前
LeetCode 148. 排序链表 —— 解法二:自底向上归并(迭代,O(1) 空间)
数据结构·算法·leetcode·链表·归并·迭代
凯瑟琳.奥古斯特14 小时前
力扣1235完整解法详解
java·开发语言·leetcode
嘿黑嘿呦14 小时前
数据结构-图论-最小生成树
数据结构·算法·图论
Justice Young15 小时前
算法分析与设计实验:贪心法求解0/1背包问题的局限性
算法
酉鬼女又兒15 小时前
零基础入门计算机网络:从基本概念到核心交换技术
开发语言·计算机网络·考研·职场和发展·php
黎阳之光15 小时前
无感定位·智管全域:黎阳之光人员无感定位管理系统,重新定义安全与效率
人工智能·物联网·算法·安全·数字孪生
小许同学记录成长15 小时前
网格简化算法 — Edge Collapse(边塌缩)
qt·算法
凯瑟琳.奥古斯特15 小时前
力扣1001网格照明解法
算法·leetcode·职场和发展