leetcode题目69:x的平方根【python】

2024-04-26 08:28

本文主要是介绍leetcode题目69:x的平方根【python】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

计算并返回 x 的平方根,其中 x 是非负整数。

由于返回类型是整数,结果只保留整数部分,小数部分将被舍去。

输入格式
  • x:一个非负整数。
输出格式
  • 返回整数部分的平方根。

示例

示例 1
输入: x = 4
输出: 2
示例 2
输入: x = 8
输出: 2
解释: 8 的平方根是 2.82842..., 因为返回类型是整数,小数部分将被舍去。

方法一:二分查找

解题步骤
  1. 设置边界:设置 left 为 0,rightx
  2. 迭代查找:在 leftright 之间使用二分查找来确定平方根。
  3. 检查中点平方:计算中点的平方,与 x 比较来调整 leftright
完整的规范代码
def mySqrt(x):"""使用二分查找计算平方根:param x: int, 输入的非负整数:return: int, 平方根的整数部分"""left, right = 0, xwhile left <= right:mid = (left + right) // 2if mid * mid <= x < (mid + 1) * (mid + 1):return midelif mid * mid < x:left = mid + 1else:right = mid - 1# 示例调用
print(mySqrt(4))  # 输出: 2
print(mySqrt(8))  # 输出: 2
算法分析
  • 时间复杂度:(O(\log n)),其中 n 是输入大小 x,二分查找的时间复杂度。
  • 空间复杂度:(O(1)),只使用了固定的几个变量。

方法二:牛顿迭代法

解题步骤

在这里插入图片描述

完整的规范代码
def mySqrt(x):"""使用牛顿迭代法计算平方根:param x: int, 输入的非负整数:return: int, 平方根的整数部分"""if x < 2:return xx0 = xx1 = (x0 + x // x0) // 2while x1 < x0:x0 = x1x1 = (x0 + x // x0) // 2return x0# 示例调用
print(mySqrt(4))  # 输出: 2
print(mySqrt(8))  # 输出: 2
算法分析
  • 时间复杂度:(O(log n)),牛顿迭代法通常具有很快的收敛速度。
  • 空间复杂度:(O(1)),使用了常数个额外空间。

方法三:内置函数法

解题步骤
  1. 直接计算:使用 Python 的内置函数 math.sqrt() 计算平方根。
  2. 结果转换:将得到的浮点数结果转换为整数。
完整的规范代码
import mathdef mySqrt(x):"""使用内置函数计算平方根:param x: int, 输入的非负整数:return: int, 平方根的整数部分"""return int(math.sqrt(x))# 示例调用
print(mySqrt(4))  # 输出: 2
print(mySqrt(8))  # 输出: 2
算法分析
  • 时间复杂度:(O(1)),内置函数通常优化良好,执行速度快。
  • 空间复杂度:(O(1)),不需要额外空间。

方法四:暴力法

解题步骤
  1. 线性搜索:从 0 开始逐一计算平方,直到平方大于 x
  2. 返回结果:返回最后一个平方不超过 x 的数。
完整的规范代码
def mySqrt(x):"""使用暴力法计算平方根:param x: int, 输入的非负整数:return: int, 平方根的整数部分"""ans = 0while (ans + 1) * (ans + 1) <= x:ans += 1return ans# 示例调用
print(mySqrt(4))  # 输出: 2
print(mySqrt(8))  # 输出: 2
算法分析
  • 时间复杂度:(O(sqrt{n})),需要计算直到 x 的平方根。
  • 空间复杂度:(O(1)),使用固定空间。

方法五:位运算法

解题步骤
  1. 位移操作:通过位操作逐步构建结果的每一位,检查平方后是否小于等于 x
  2. 迭代构建结果:从最高位开始尝试,逐步向下调整。
完整的规范代码
def mySqrt(x):"""使用位运算法计算平方根:param x: int, 输入的非负整数:return: int, 平方根的整数部分"""ans = 0bit = 1 << 15  # 从高位开始尝试while bit > 0:ans |= bitif ans * ans > x:ans ^= bit  # 如果尝试结果过大,撤销这一位bit >>= 1return ans# 示例调用
print(mySqrt(4))  # 输出: 2
print(mySqrt(8))  # 输出: 2
算法分析
  • 时间复杂度:(O(log n)),位运算的复杂度为常数次迭代。
  • 空间复杂度:(O(1)),不需要额外空间。

不同算法的优劣势对比

特征方法一:二分查找方法二:牛顿迭代法方法三:内置函数法方法四:暴力法方法五:位运算法
时间复杂度(O(log n))(O(log n))(O(1))(O(sqrt{n}))(O(log n))
空间复杂度(O(1))(O(1))(O(1))(O(1))(O(1))
优势稳定且高效收敛速度快,适用于大数实现简单,运行快速直观易懂不使用乘法和除法,节省资源
劣势需要处理边界条件初始值依赖较大受内置函数性能限制时间成本较高代码相对复杂,需要位操作知识

应用示例

图形处理软件:在处理图形和游戏开发中,经常需要计算对象的大小或者距离,这时候求平方根是常见的需求。例如,计算点到原点的距离,确定对象是否在视野内等。不同的平方根计算方法可以根据性能需求和精确度要求选择。例如,位运算法因为其高效性,非常适合嵌入式系统或游戏开发中,牛顿迭代法则适用于需要高精度计算的科学计算软件。

这篇关于leetcode题目69:x的平方根【python】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一