LeetCode 279. 完全平方数(经典必会)

news2024/10/24 19:28:58

LeetCode 279. 完全平方数

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量 。
完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,1、4、9 和 16 都是完全平方数,而 3 和 11 不是。
示例 1:
输入:n = 12
输出:3
解释:12 = 4 + 4 + 4
示例 2:
输入:n = 13
输出:2
解释:13 = 4 + 9
提示:
1 <= n <= 104

动态规划

class Solution:
    def numSquares(self, n: int) -> int:
        # dp[i] 表示和为i的完全平方数的最少数量
        # dp[i] = min{dp[i - j * j] + 1} j from 1 to sqrt(i)

        dp = [i for i in range(n + 1)]
        for i in range(2, n + 1):
            j = 1
            while j <= math.sqrt(i):
                dp[i] = min(dp[i], dp[i - j * j] + 1)
                j += 1
        return dp[n]

时间复杂度: O ( n n ) O(n\sqrt{n}) O(nn )。第一层循环为n,第二层循环为 n \sqrt{n} n ,但并不是每次外层循环第二层循环都是 n \sqrt{n} n ,若第一层为第i次循环,第二层循环次数为 i \sqrt{i} i 。这时可以基于二维图像快速分析时间复杂度:

双层循环基于二维图像和夹逼定理思想快速分析渐进复杂度

首先,对于如下程序

for i in range(n):
    for i in range(n):
    	...

毫无疑问,第一层循环必定循环n次,而第二层循环当在每次的第一层循环时都会循环n次,则时间复杂度为 O ( n 2 ) O(n^2) O(n2)
已第一层循环次数为x轴,第二层循环次数为y轴,易得:
在这里插入图片描述
假定横纵坐标最大值为n

显然围成的矩形面积n*n就是渐进意义上的时间复杂度

同理,分析下面程序

for i in range(n):
    for i in range(n//2):
    	...

在这里插入图片描述
图中三角形面积n*n/2即为时间复杂度

对于上述动态规划解法,第一层循环为n,第二层循环次数为第一层循环次数i的 i \sqrt{i} i ,说白了就是外层循环作为x,二层循环作为y,有 y = x y=\sqrt{x} y=x 关系,求x=n时该图像与x轴和x=n围成的面积。

本质上时间复杂度为 1 + 2 + 3 + 4 + . . . + n ) 1+\sqrt2+\sqrt3+\sqrt4+...+\sqrt{n}) 1+2 +3 +4 +...+n ),心算不好算,而且有时候笔算也不一定会推导,所以基于函数图像和夹逼定理思想会较为容易

在这里插入图片描述
显然 y = x y=\sqrt{x} y=x x = n x=n x=n y = 0 y=0 y=0围成的面积一定小于 n n n\sqrt{n} nn ,即图中虚线矩形面积。
此时需要取x的一个特殊值 x 0 x_0 x0帮我我们使用夹逼定理思想,假设 x 0 x_0 x0 n 2 \frac{n}{2} 2n,则 y 0 = n 2 y_0=\sqrt{\frac{n}{2}} y0=2n ,由于该函数递增,不妨x取 [ n 2 , n ] [\frac{n}{2},n] [2n,n]段,让y恒等于 n 2 \sqrt{\frac{n}{2}} 2n ,就是图中实线矩形,则一定有:
实矩形面积 < x \sqrt{x} x 围成的面积<虚线矩形面积
加上等号也成立
实矩形面积 <= x \sqrt{x} x 围成的面积<=虚线矩形面积

假设围成的面积为f(n),则时间复杂度T就是O(f(n))


( n − n 2 ) n 2 ≤ f ( n ) ≤ n n (n-\frac{n}{2})\sqrt{\frac{n}{2}}\leq{f(n)}\leq{n}\sqrt{n} (n2n)2n f(n)nn

n n 2 2 ≤ f ( n ) ≤ n n \frac{n\sqrt{n}}{2\sqrt2}\leq{f(n)}\leq{n}\sqrt{n} 22 nn f(n)nn

取渐进大O
O ( n n 2 2 ) ≤ O ( f ( n ) ) ≤ O ( n n ) {O(\frac{n\sqrt{n}}{2\sqrt2})}\leq{O(f(n))}\leq{O({n}\sqrt{n})} O(22 nn )O(f(n))O(nn )
O ( n n ) ≤ O ( f ( n ) ) ≤ O ( n n ) {O({n}\sqrt{n})}\leq{O(f(n))}\leq{O({n}\sqrt{n})} O(nn )O(f(n))O(nn )

显然 T = O ( n n ) T=O({n}\sqrt{n}) T=O(nn )

总结一下,整体上就是根据二维图像找面积,上界通常容易找,但是下界需要找一个 x 0 x_0 x0,通常 x 0 x_0 x0一定含n,具体问题具体分析,本题中n取 n 2 \frac{n}{2} 2n还是取 n 3 \frac{n}{3} 3n,亦或 n 4 \frac{n}{4} 4n都不影响分析,重要的是能使用夹逼定理思想就行。

空间复杂度: O ( n ) O(n) O(n)。n+1的空间存储状态。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2211065.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java中连接Mysql以及PreparedStatement如何防止sql注入

目录 JDBC 使用JDBC连接到MySQL 使用 Statement 使用 PreparedStatement Statement 和 PreparedStatement 区别 在 java 中如何连接到 MySQL 数据库&#xff0c;执行 SQL 查询&#xff0c;并处理查询结果&#xff1f; JDBC java 程序连接到 mysql&#xff0c;首先需要下…

Dev-C++萌新福利2

朝鲜球作品原创 1 符号认识&#xff1a; 1.1简单例题1 1.2简单例题22奇奇怪怪的符号 2.1简单例题3 2.2符号表 2.2.1符号表中特殊符号 2.3符号使用代码样例&#xff08;部分&#xff09; 萌新福利 作品成本6999元&#xff0…

OSError: [Errno 22] Invalid argument:无效的参数完美解决方法

&#x1f6a8; OSError: [Errno 22] Invalid argument&#xff1a;无效的参数完美解决方法 &#x1f4a1; &#x1f6a8; OSError: [Errno 22] Invalid argument&#xff1a;无效的参数完美解决方法 &#x1f4a1;摘要引言正文1. 什么是 OSError: [Errno 22] Invalid argument&…

牛客.数字游戏​编辑牛客.体操队形(暴力搜索)​​​​​​​牛客.二叉树最大路径和​编辑牛客.排序子序列

目录 牛客.数字游戏​编辑 牛客.体操队形(暴力搜索) 牛客.二叉树最大路径和​编辑 牛客.排序子序列 牛客.数字游戏 难度不大&#xff0c;但是要注意&#xff0c;他这个快速输入与输出 import java.util.*; import java.io.*; import java.util.StringTokenizer; // 注意类名…

架构设计笔记-15-面向服务架构设计理论与实践

目录 知识要点 案例分析 1.微服务架构 2.微服务 3.微服务架构 4.SOA与微服务 5.基于微服务架构的系统/传统单体式系统 论文 1.论微服务架构及其应用 知识要点 服务组件体系结构&#xff08;Service Component Architecture&#xff0c;SCA&#xff09;是面向服务体系…

IT基础监控运维:监控易的深度解析与应用

在数字化转型加速的今天&#xff0c;IT系统的稳定性和高效运维成为了企业业务连续性的关键保障。IT基础监控作为运维工作的基石&#xff0c;其重要性不言而喻。本文将以监控易产品为核心&#xff0c;深入探讨IT基础监控的功能、特点及范围&#xff0c;为运维团队提供实用的参考…

销售管理之线索管理

一、线索获取&#xff1a;销售增长与市场洞察的双引擎 销售增长的基石 线索&#xff1a;销售旅程的起点&#xff1a;在销售的宏伟蓝图中&#xff0c;高质量的线索无疑是构筑成功的基石。缺乏持续、优质的线索供应&#xff0c;任何销售团队都难以跨越销售目标的重重山峦。以软…

Apktool:解包重打包工具

ApKtool是一个apk编译工具&#xff0c;能够反编译apk文件。 解包 使用命令apktool d test.apk 会在同目录下生成一个同名的文件夹 重打包 使用命令apktool b test 会在test文件夹里生成一个dist目录&#xff0c;在dist目录里有打包好的test.apk

Top6 最好的 Android 数据恢复软件免费获取

虽然在智能手机上随身携带您最喜爱的音乐收藏或珍贵的录音很方便&#xff0c;但如果您的设备出现技术问题或您不小心删除了文件&#xff0c;文件也有可能丢失。 不管文件是如何删除或丢失的&#xff0c;丢失那些珍贵的音频文件的痛苦对每个人来说都是一样的。这就是我们创建本…

鸿蒙开发之ArkUI 界面篇 三十三 Builder(封装容器)

鸿蒙开发中遇到容器相同、容器下面的子组件相同&#xff0c;就是子组件的文字不同&#xff0c;背景颜色不同&#xff0c;文字颜色不同之类&#xff0c;就可以使用Builder来封装&#xff0c;语法格式如下&#xff1a; 例如下面的界面&#xff1a; Row4个ColumImageText来实现&am…

Java初阶测试编程题目

文章目录 1.大小写转换2.斐波那契数列2.1递归解决&#xff08;不推荐&#xff09;2.2递推公式&#xff08;非递归&#xff09; 3.删除公共字符3.1题目说明3.2第一种方法3.3第二种方法 4.字符串的加法4.1题目说明4.2题目核心方法4.3题目代码解析 Java初阶测试编程题目分析与总结…

C++第六讲:STL--vector的使用及模拟实现

C第六讲&#xff1a;STL--vector的使用及模拟实现 1.vector简介2.vector的常见接口介绍2.1constructor -- 构造2.2destructor -- 析构2.3begin、end2.3.1vector和string的区别、vector<string> 2.4rbegin、rend2.5cbegin、cend2.6crbegin、crend2.7size、max_size、resiz…

C++AVL树的介绍和实现

目录 1.AVL树的概念 2.AVL树的实现 2.1AVL树的结构 2.2AVL树的插入 2.2.1AVL树插入一个值的大概过程 2.2.2平衡因子的更新 2.2.3插入节点及更新平衡因子的代码实现(暂未实现旋转逻辑) 2.3旋转 2.3.1旋转的原则 2.3.2右单旋(处理parent->_bf -2 && cur-&g…

简易入门:使用Docke 部署一个tomcat服务

简易入门&#xff1a;使用Docke 部署一个tomcat服务 # 拉取 >docker pull tomcat:9.0# 后台运行容器&#xff0c;端口映射为8080. -p 宿主机端口:容器端口 >docker run -d --name tomcat-c-01 -p 8080:8080 tomcat:9.0# 查看容器id >docker ps CONTAINER ID IMAG…

Qt-系统线程安全(63)

目录 描述 使用 线程不安全 线程安全 释放锁问题 其他的锁 条件变量和信号量 描述 多线程程序太复杂了 在C/C 和 Linux中&#xff0c;我们为了保证线程安全&#xff0c;简单的方式就是加锁 为此 Qt 也封装了自己的一套锁管理 使用 线程不安全 我们先测验一下线程不安…

七、程序流程控制

一、三种执行顺序 执行顺序说明顺序结构自上而下的执行代码分支结构根据条件&#xff0c;选择对应代码执行循环结构控制某段代码重复执行 二、分支结构 1、if 分支 根据条件&#xff08;真或假&#xff09;来决定执行某段代码if 分支有三种形式 //第一种形式 if(条件表达式…

Qt学习(一)——win10系统下Qt安装(Qt5.15.2+QtCreator5.0.3+MSVC2019)

win10平台下&#xff0c;Qt Creator 5.0.3 软件About Qt Creator界面如下&#xff1a; 其基于Qt 5.15.2 MSVC2019&#xff0c;64bit,故在用Qt4 设计师自定义控件所设计的控件能够被Qt Creator加载到&#xff0c;就要安装相应版本的Qt和MSVC。此安装便可支持win10系统下的自定义…

Java项目实战II基于Java+Spring Boot+MySQL的足球青训俱乐部管理后台系统的设计与开发(源码+数据库+文档)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 足球作为世…

【hot100-java】排序链表

链表题。 使用归并排序法。 一图解决。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val) { this.val val; }* ListNode(int val, ListNode next) { this.val val; thi…

(刷题记录6)三数之和

三数之和 题目信息&#xff1a;题目思路(环境来自力扣OJ的C)&#xff1a;暴力枚举&#xff1a;双指针&#xff1a;在三数之和上&#xff1a;转化成的两数之和&#xff1a;两数之和小优化&#xff1a; 复杂度&#xff1a;代码和解释&#xff1a;暴力枚举&#xff1a;双指针&…