当前位置: 首页 > news >正文

LeetCode:279.完全平方数

在这里插入图片描述

class Solution:def numSquares(self, n: int) -> int:dp=[i for i in range(n+1)]for i in range(2,n+1):for j in range(1,int(i**(0.5))+1):dp[i]=min(dp[i],dp[i-j*j]+1)return dp[-1]

代码解释

  1. 初始化 DP 数组
    dp = [i for i in range(n+1)]
    这里,dp[i] 表示数字 i 可以由多少个完全平方数组成。初始时,假设每个数字都由它本身一个完全平方数组成,即 dp[i] = i
  2. 动态规划
    外层循环遍历从 2 到 n 的所有数字 i
    内层循环遍历从 1 到 sqrt(i) 的所有整数 j。这里 j 是可能的完全平方数的平方根。
    对于每个 ij,我们尝试将 i 分解为 j*ji-j*j 两部分。如果 i-j*j 仍然是非负的,那么 dp[i] 可以更新为 dp[i-j*j] + 1(即 i-j*j 所需的完全平方数加上当前的 j*j)。
    但是,我们要确保 dp[i] 始终是最小的值,因此我们使用 min(dp[i], dp[i-j*j]+1) 来更新它。
  3. 返回结果
    最后,dp[-1] 就是 n 可以由的最少完全平方数之和,因为 dp 数组的下标是从 0 到 n 的。

举例

假设 n = 12

初始时,dp 数组为:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]

开始动态规划:

  • i = 2j 可以是 1,因为 2 = 1*1 + 1*1(但这里我们只使用一个平方数),所以 dp[2] = 1
  • i = 3j 只能是 1,因为 3 = 1*1 + 2,但 2 不是一个完全平方数,所以 dp[3] 保持为 3
  • i = 4j 可以是 1 或 2,因为 4 = 1*1 + 34 = 2*2,后者更优,所以 dp[4] = 1
  • i = 12,我们考虑所有可能的 j 值,并找到最佳组合。最终,12 = 4 + 4 + 4(或 12 = 1 + 3 + 8 等,但 4+4+4 是最少的),所以 dp[12] = 3

最终,dp[-1](即 dp[12])为 3,表示 12 可以由 3 个完全平方数组成。

http://www.lryc.cn/news/354745.html

相关文章:

  • Python面试宝典:Python中与ORM技术(对象关系映射)相关的面试笔试题(1000加面试笔试题助你轻松捕获大厂Offer)
  • VUE3+TS+elementplus创建table,纯前端的table
  • UE驻网失败问题(二)
  • 【MySQL】第三周作业
  • 香橙派 Kunpeng Pro使用教程:从零开始打造个人私密博客
  • 深入探索:中文字符的编码与转移字符的奥秘
  • Ubuntu中 petalinux 安装 移植linux --tftp/tftp-hpa服务的方法
  • JVM(内存区域划分、类加载机制、垃圾回收机制)
  • C语言---基础内容(万字)
  • c语言从入门到函数速成(完结篇)
  • 关于linux磁盘告警问题
  • 冯喜运:5.27黄金暴跌大阴后出现“暂定符”今日黄金原油操作策略
  • 前端JS必用工具【js-tool-big-box】学习,获取全球重点城市时间
  • BioTech - 将蛋白质的 PDB 格式文件 转换成 mmCIF 格式文件 (Python)
  • 【编程题-错题集】奇数位丢弃(模拟 - 规律)
  • Docker安装MongoDB(Linux版)
  • 【设计模式】JAVA Design Patterns——Commander(指挥官模式)
  • 解决vue3项目vite打包忽略.vue扩展名
  • Vue基础(数据绑定、export使用)
  • 【传知代码】基于图神经网络的知识追踪方法(论文复现)
  • Vue与React、Angular的比较
  • LINQ(二) —— 流式语句
  • 怎么查看MySQL服务的最大连接,已经使用的连接数?怎么配置最大连接数?
  • 微信小程序毕业设计-跑腿系统项目开发实战(附源码+演示视频+LW)
  • stm32通过esp8266连接阿里云平台代码讲解
  • 突发!某大厂机房掉电,MySQL数据库无法启动,紧急恢复过程...
  • SpringCloudAlibaba:6.2RocketMQ的普通消息的使用
  • vue+echart :点击趋势图中的某一点或是柱状图,出现弹窗,并传输数据
  • 2024年上半年软考什么时候查成绩?附查询流程
  • css3实现0.5px边框