代码随想录 -- 动态规划 -- 完全平方数

279. 完全平方数 - 力扣(LeetCode)

思路:

  • dp[j]的含义:组成和为n最少需要dp[j]个完全平方数
  • 递推公式:dp[j]=min(dp[j],dp[j-i*i]+1)
  • 初始化:dp[0]=0,其他的初始化为比10000还大的数
  • 遍历顺序:先物品后背包
python 复制代码
class Solution(object):
    def numSquares(self, n):
        dp=[10010]*(n+1)
        dp[0]=0
        for i in range(1,n/2+2):
            for j in range(i*i,n+1):
                dp[j]=min(dp[j],dp[j-i*i]+1)
        return dp[n]
相关推荐
free-elcmacom2 小时前
深度学习<4>高效模型架构与优化器的“效率革命”
人工智能·python·深度学习·机器学习·架构
liliangcsdn2 小时前
python模拟beam search优化LLM输出过程
人工智能·python
源代码•宸3 小时前
Leetcode—620. 有趣的电影&&Q3. 有趣的电影【简单】
数据库·后端·mysql·算法·leetcode·职场和发展
王琦03183 小时前
Python 函数详解
开发语言·python
胡伯来了3 小时前
13. Python打包工具- setuptools
开发语言·python
2301_800256113 小时前
地理空间数据库中的CPU 和 I/O 开销
数据库·算法·oracle
小鸡吃米…4 小时前
Python 中的多层继承
开发语言·python
中國移动丶移不动4 小时前
Python MySQL 数据库操作完整示例
数据库·python·mysql
落叶,听雪4 小时前
AI建站推荐
大数据·人工智能·python
ZAz_4 小时前
DAY 45 预训练模型
python