力扣第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 的最少完全平方数数量。
相关推荐
Zephyr_033 分钟前
Leedcode算法题
java·算法
流年如夢1 小时前
栈和列队(LeetCode)
数据结构·算法·leetcode·链表·职场和发展
Hello.Reader2 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
逻辑驱动的ken3 小时前
Java高频考点场景题24
java·开发语言·面试·职场和发展·求职招聘
绛橘色的日落(。・∀・)ノ3 小时前
机器学习之评估与偏差方差分析
算法
消失的旧时光-19433 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
AI_Ming4 小时前
从0开始学AI:层归一化,原来是这回事!
算法·ai编程
WL_Aurora4 小时前
备战蓝桥杯国赛【Day 8】
算法·蓝桥杯
智者知已应修善业4 小时前
【51单片机模拟生日蜡烛】2023-10-10
c++·经验分享·笔记·算法·51单片机
MediaTea4 小时前
Scikit-learn:从数据到结构——无监督学习的最小闭环
人工智能·学习·算法·机器学习·scikit-learn