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

网站开发 书籍域名备案查询

网站开发 书籍,域名备案查询,如何做app 的模板下载网站,南宁网站设计制作公司LeetCode 第279题:完全平方数 📖 文章摘要 本文详细解析LeetCode第279题"完全平方数",这是一道经典的动态规划问题。文章提供了动态规划和数学方法两种解题思路,包含C#、Python、C三种语言实现,配有详细的…

LeetCode 第279题:完全平方数

📖 文章摘要

本文详细解析LeetCode第279题"完全平方数",这是一道经典的动态规划问题。文章提供了动态规划和数学方法两种解题思路,包含C#、Python、C++三种语言实现,配有详细的状态转移表格和性能对比。适合学习动态规划和数学优化的读者。

核心知识点: 动态规划、完全平方数、数学定理
难度等级: 中等
推荐人群: 具备基础算法知识,想要提升动态规划技能的开发者

题目描述

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量

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

示例

示例 1:

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

示例 2:

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

提示

  • 1 <= n <= 10^4

解题思路

本题可以使用动态规划来解决,也可以使用数学方法。我们主要介绍这两种方法:

  1. 动态规划方法:

    • 定义dp[i]表示数字i最少需要多少个完全平方数
    • 对于每个数i,枚举所有小于等于i的完全平方数j*j
    • 状态转移方程:dp[i] = min(dp[i], dp[i - j*j] + 1)
  2. 数学方法(四平方和定理):

    • 任何正整数都可以表示为至多4个平方数之和
    • 当且仅当n≠4^k(8m+7)时,n可以表示为至多3个平方数之和

图解思路

动态规划状态转移表

数字n可用平方数dp[n]组成方式说明
1111基础情况
2121+1只能用1
3131+1+1只能用1
41,414可以直接用4
51,424+1使用4和1
121,4,934+4+4使用三个4
131,4,924+9使用4和9

数学方法分析表

情况条件结果示例说明
完全平方数n = k^2116=4^2直接是平方数
两个平方数和n = a^2 + b^2213=4+9可以分解为两个平方数之和
三个平方数和n ≠ 4^k(8m+7)312=4+4+4可以分解为三个平方数之和
四个平方数和其他情况47=4+1+1+1需要四个平方数

代码实现

C# 实现

public class Solution {public int NumSquares(int n) {// 创建dp数组,初始值设为最大可能值int[] dp = new int[n + 1];Array.Fill(dp, int.MaxValue);dp[0] = 0;// 计算所有小于等于n的完全平方数int maxSquareRoot = (int)Math.Sqrt(n);int[] squares = new int[maxSquareRoot];for (int i = 1; i <= maxSquareRoot; i++) {squares[i - 1] = i * i;}// 动态规划过程for (int i = 1; i <= n; i++) {for (int j = 0; j < maxSquareRoot && squares[j] <= i; j++) {dp[i] = Math.Min(dp[i], dp[i - squares[j]] + 1);}}return dp[n];}
}

Python 实现

class Solution:def numSquares(self, n: int) -> int:# 创建dp数组dp = [float('inf')] * (n + 1)dp[0] = 0# 计算所有小于等于n的完全平方数squares = [i * i for i in range(1, int(n ** 0.5) + 1)]# 动态规划过程for i in range(1, n + 1):for square in squares:if square > i:breakdp[i] = min(dp[i], dp[i - square] + 1)return dp[n]

C++ 实现

class Solution {
public:int numSquares(int n) {// 创建dp数组vector<int> dp(n + 1, INT_MAX);dp[0] = 0;// 计算所有小于等于n的完全平方数int maxSquareRoot = (int)sqrt(n);vector<int> squares(maxSquareRoot);for (int i = 1; i <= maxSquareRoot; i++) {squares[i - 1] = i * i;}// 动态规划过程for (int i = 1; i <= n; i++) {for (int j = 0; j < maxSquareRoot && squares[j] <= i; j++) {dp[i] = min(dp[i], dp[i - squares[j]] + 1);}}return dp[n];}
};

执行结果

C# 实现

  • 执行用时:84 ms
  • 内存消耗:27.8 MB

Python 实现

  • 执行用时:148 ms
  • 内存消耗:15.2 MB

C++ 实现

  • 执行用时:44 ms
  • 内存消耗:9.1 MB

性能对比

语言执行用时内存消耗特点
C#84 ms27.8 MB代码结构清晰,性能适中
Python148 ms15.2 MB代码最简洁,但运行较慢
C++44 ms9.1 MB性能最优,内存占用最小

代码亮点

  1. 🎯 使用动态规划优化时间复杂度
  2. 💡 预计算完全平方数数组,避免重复计算
  3. 🔍 使用Math.Min/min优化比较操作
  4. 🎨 代码结构清晰,变量命名直观

常见错误分析

  1. 🚫 未初始化dp数组为最大值
  2. 🚫 完全平方数计算范围错误
  3. 🚫 状态转移方程写错
  4. 🚫 边界条件处理不当

解法对比

解法时间复杂度空间复杂度优点缺点
动态规划O(n * sqrt(n))O(n)通用性强空间消耗大
数学方法O(sqrt(n))O(1)速度快需要数学知识
BFSO(n * sqrt(n))O(n)思路直观空间消耗大

相关题目

  • LeetCode 263. 丑数 - 简单
  • LeetCode 264. 丑数 II - 中等
  • LeetCode 313. 超级丑数 - 中等

📖 系列导航

🔥 算法专题合集 - 查看完整合集

📢 关注合集更新:点击上方合集链接,关注获取最新题解!目前已更新第279题。

💬 互动交流

感谢大家耐心阅读到这里!希望这篇题解能够帮助你更好地理解和掌握这道算法题。

如果这篇文章对你有帮助,请:

  • 👍 点个赞,让更多人看到这篇文章
  • 📁 收藏文章,方便后续查阅复习
  • 🔔 关注作者,获取更多高质量算法题解
  • 💭 评论区留言,分享你的解题思路或提出疑问

你的支持是我持续分享的动力!

💡 一起进步:算法学习路上不孤单,欢迎一起交流学习!

http://www.dtcms.com/wzjs/498331.html

相关文章:

  • 温州网站制作价格产品推广方法
  • 网站建设公司佛山2023年8月新闻热点事件
  • 网站建设教材下载网站怎么添加外链
  • 官方网站下载baiduwangpan优化大师官方网站
  • 三星企业网站建设ppt百度手机快速排名点击软件
  • 开发一个电商网站久久seo正规吗
  • 合浦县城乡规划建设局网站廊坊关键词快速排名
  • 网站建设与管理专业是什么百度搜索推广是什么
  • 滁州网站建设百度知道登录入口
  • 女教师遭网课入侵直播百度seo排名优化软件分类
  • 重庆公司建设网站百度快照怎么删除
  • 广陵区建设局网站app广告联盟
  • 内部网站做域名解析到端口百度会员登录入口
  • 娄底网站开发北京网络营销公司排名
  • 网页微信登录百度seo搜索营销新视角
  • 做器材的网站个人博客模板
  • 返利网 网站开发软件商店安装
  • 建设一个网站需要条件网页制作图片
  • 网站可以做多少优化关键词福建seo顾问
  • 网站建设培训学院sem工具是什么
  • 网站开发网页跳转到新的页面百度首页网址
  • 网站你懂我意思正能量晚上常用的五种网络营销工具
  • 小型手机网站建设企业网络推广赚钱
  • 曰本做爰视频网站企业网络营销策略
  • isp网站接入做哪些业务腾讯朋友圈广告怎么投放
  • 做网站开发怎么接单海外推广营销 平台
  • 网站加速免费网络营销推广外包服务
  • 网页设计公司建设网站今日新闻播报
  • 竭诚网络网站建设开发2020 惠州seo服务
  • h5移动端网站模板下载重庆百度推广开户