力扣第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 的最少完全平方数数量。
相关推荐
juleskk1 小时前
3.22 复试训练
算法
2301_776508721 小时前
分布式系统监控工具
开发语言·c++·算法
暮冬-  Gentle°2 小时前
C++与区块链智能合约
开发语言·c++·算法
愣头不青2 小时前
78.子集
数据结构·算法
Oueii2 小时前
C++中的代理模式实现
开发语言·c++·算法
3DVisionary2 小时前
从微观损伤到宏观断裂:DIC非接触测量在复合材料可靠性验证中的前沿实践
人工智能·数码相机·算法·机器学习·3d·复合材料·dic技术
sheeta19982 小时前
LeetCode 每日一题笔记 日期:2025.03.22 题目:1886.判断矩阵经轮转后是否一致
笔记·leetcode·矩阵
sonnet-10292 小时前
拓扑排序的实现
java·c语言·开发语言·笔记·算法
米粒12 小时前
力扣算法刷题 Day 20
算法·leetcode·职场和发展