【动态规划】Leetcode 279. 完全平方数【中等】

2024-04-25 13:28

本文主要是介绍【动态规划】Leetcode 279. 完全平方数【中等】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

完全平方数

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

完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,1、4、9 和 16 都是完全平方数,而 3 和 11 不是。

示例 1:

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

解题思路

  • 1、使用动态规划求解,定义一个一维数组dp,其中dp[i]表示和为i的完全平方数的最少数量。
  • 2、初始化数组dp,长度为n + 1,全部初始化为最大值,dp[0]为0。
  • 3、对于每个数字i,遍历从1到sqrt(i)的完全平方数j*j,更新dp[i]为dp[i - j * j] + 1和dp[i]中的较小值。
    动态规划的状态转移方程为:
  •   dp[i] = min(dp[i], dp[i - j * j] + 1),其中 1 <= j * j <= i
    
    这个方程的意思是,如果当前的数 i 可以由 j * j 和 i - j * j 组成,那么 dp[i] 就可以通过 dp[i - j * j] + 1 来更新,即将 j * j 加入到和为 i 的完全平方数的组合中。
  • 4、最终返回dp[n]即可。

Java实现

public class PerfectSquares {public int numSquares(int n) {int[] dp = new int[n + 1];Arrays.fill(dp, Integer.MAX_VALUE);dp[0] = 0;/*** 首先,定义一个数组 dp[],其中 dp[i] 表示组成数值 i 的最小平方数数量。** 然后,通过两层循环遍历所有可能的数值 i,从 1 到 n。** 内层循环中,对于当前数值 i,我们尝试找到组成它的最小平方数数量。* 我们遍历所有小于等于 i 的平方数,记为 j * j,并更新 dp[i] 的值为* dp[i - j * j] + 1 的最小值。也就是说,我们找到了一个平方数 j * j,* 并尝试用它去更新 i 的最小平方数数量,看是否可以得到更优的解。** 最终,当外层循环结束时,dp[n] 中存储的就是组成数值 n 的最小平方数数量。* 这种解法的核心思想是利用动态规划的思想,* 通过计算子问题的最优解来构建更大规模问题的最优解。* 通过从小到大的顺序计算所有可能的数值 i,我们可以确保在计算 dp[i] 时,* dp[i - j * j] 已经计算过了,并且存储了正确的结果,* 从而确保每个状态的最优解被正确计算出来。*/for (int i = 1; i <= n; i++) {for (int j = 1; j * j <= i; j++) {dp[i] = Math.min(dp[i], dp[i - j * j] + 1);}}return dp[n];}public static void main(String[] args) {PerfectSquares ps = new PerfectSquares();int n = 12;System.out.println("Minimum number of perfect squares: " +ps.numSquares(n)); // Output: 3 (12 = 4 + 4 + 4)}
}

时间空间复杂度

  • 时间复杂度:外层循环遍历了n次,内层循环遍历了sqrt(n)次,时间复杂度为O(n * sqrt(n))。

  • 空间复杂度:使用了长度为n + 1的数组dp,空间复杂度为O(n)。

这篇关于【动态规划】Leetcode 279. 完全平方数【中等】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934811

相关文章

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Linux find 命令完全指南及核心用法

《Linuxfind命令完全指南及核心用法》find是Linux系统最强大的文件搜索工具,支持嵌套遍历、条件筛选、执行动作,下面给大家介绍Linuxfind命令完全指南,感兴趣的朋友一起看看吧... 目录一、基础搜索模式1. 按文件名搜索(精确/模糊匹配)2. 排除指定目录/文件二、根据文件类型筛选三、时间

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu

JavaScript中的Map用法完全指南

《JavaScript中的Map用法完全指南》:本文主要介绍JavaScript中Map用法的相关资料,通过实例讲解了Map的创建、常用方法和迭代方式,还探讨了Map与对象的区别,并通过一个例子展... 目录引言1. 创建 Map2. Map 和对象的对比3. Map 的常用方法3.1 set(key, v