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

网站开发 书籍网站推荐

网站开发 书籍,网站推荐,深圳市做物流网站,电商网站功能模块图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/83863.html

相关文章:

  • 桂林漓江在哪个位置seo每日一帖
  • 打电话说帮忙做网站谷歌chrome官网
  • 中老年适合在哪个网站做直播天津seo优化公司
  • 网站设计自已申请对百度竞价排名的看法
  • 中文绿色环保网站模板企业软文范例
  • 成都微信网站设计优化大师
  • 河南新乡做网站公司哪家好厦门网站优化公司
  • 网站建设在国外成都网站维护
  • 在意派建设好网站后惠州百度推广优化排名
  • 动态网站开发实训心得网站关键词推广
  • 做神马网站快速快速seo优化
  • 黑龙江省建设官方网站汕头seo收费
  • 全国公安机关网站备案百度浏览器官网
  • 做动态h5的网站香水推广软文
  • 网站客户体验网站seo 优化
  • 不会编码可以做网站优化吗今日头条热搜榜
  • vue 做企业网站制作网站的app
  • 宝塔怎么做第二个网站推广关键词排名
  • 建站教程的特点google搜索引擎入口网址
  • 电商网站商品页的优化目标是什么?营销软文案例
  • 深圳网站设计定制开发南宁白帽seo技术
  • python企业网站开发谷歌seo 外贸建站
  • 网站开发的五个阶段手机上如何制作自己的网站
  • 政府部门网站建设费用搜索引擎营销的特点
  • 智能网站系统可以做app吗故事式软文广告300字
  • 网站建设费往什么科目地推拉新app推广平台
  • 做网站的公司叫什么名字深圳广告策划公司
  • 做游戏视频网站要批证吗杭州seo排名优化外包
  • 岳阳市内从事网站建设的公司公司推广咨询
  • 湘潭做网站 磐石网络很专业seo的内容怎么优化