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

devtools/2024/9/24 23:57:06/

题目描述

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

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

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

示例

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

方法一:二分查找

解题步骤
  1. 设置边界:设置 left 为 0,rightx
  2. 迭代查找:在 leftright 之间使用二分查找来确定平方根。
  3. 检查中点平方:计算中点的平方,与 x 比较来调整 leftright
完整的规范代码
python">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)),只使用了固定的几个变量。

方法二:牛顿迭代法

解题步骤

在这里插入图片描述

完整的规范代码
python">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. 结果转换:将得到的浮点数结果转换为整数。
完整的规范代码
python">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 的数。
完整的规范代码
python">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. 迭代构建结果:从最高位开始尝试,逐步向下调整。
完整的规范代码
python">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))
优势稳定且高效收敛速度快,适用于大数实现简单,运行快速直观易懂不使用乘法和除法,节省资源
劣势需要处理边界条件初始值依赖较大受内置函数性能限制时间成本较高代码相对复杂,需要位操作知识

应用示例

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


http://www.ppmy.cn/devtools/16465.html

相关文章

Vim学习笔记01~04

第01章&#xff1a; 遁入空门&#xff0c;模式当道 1.什么是vim Vim是一个高效的文本编辑工具&#xff0c;并且可以在编程开发过程中发挥越来越重要的作用。 事实上&#xff0c;有不少编程高手使用他们来进行代码的开发&#xff0c;并且对此赞不绝口。 2.本系列目的 但是让…

1、k8s问题pod从service中剔除

一、起因 redis原来由两服务器的集群变为三服务器的集群&#xff0c;通过statefulset扩展了两节点&#xff0c;并把redis-app-0和redis-app-3从集群中去除&#xff0c;但是由于service路由后端不变&#xff0c;导致程序连接后端仍然可能到redis-app-0和redis-app-3 二、处理 …

GitHub/R3D3项目环境配置踩坑记录

1、前言 项目链接地址&#xff1a;SysCV/r3d3 (github.com) 按照安装步骤容易出现的问题&#xff0c;environment.yaml文件中安装相关包&#xff0c;其中还有两个pip install githttps://github.com/..........这两个建议注释掉&#xff0c;后面再来安装这两个。 2、问题及解…

自然语言处理(NLP)技术

自然语言处理&#xff08;NLP&#xff09;技术是一种处理和分析人类语言的技术&#xff0c;它可以帮助计算机理解、解释和生成自然语言。 以下是一些常见的使用NLP技术的例子&#xff1a; 1. 机器翻译&#xff1a;NLP技术可以将一种语言翻译成另一种语言&#xff0c;比如将英…

深度学习中的黑科技:自监督学习(Self-Supervised Learning)

在人工智能领域&#xff0c;深度学习已成为推动技术革新的核心力量。然而&#xff0c;深度学习的一个重要瓶颈是对大量标记数据的依赖性。在这个背景下&#xff0c;自监督学习(Self-Supervised Learning, SSL)作为一种新兴的学习范式&#xff0c;越来越受到研究者的关注。自监督…

ClickHouse 数据类型、表引擎与TTL

文章目录 数据类型注意事项 表引擎1.TinyLog 引擎2.MergeTree 引擎3.ReplacingMergeTree 引擎4.AggregatingMergeTree 引擎5.SummingMergeTree 引擎6.CollapsingMergeTree 引擎7.Distributed 引擎 TTL列级 TTL表级TTL 数据类型 ClickHouse 数据类型Java 数据类型数据范围UInt8…

DevOps(十二)Jenkins实战之Web发布到远程服务器

前面两篇博文介绍了怎么将django开发的web应用推送到gitlab源码仓库&#xff0c;然后jenkins服务器从gitlab仓库拉下来&#xff0c;布署到jenkins服务器上&#xff0c;并用supervisor进行进程管理&#xff0c;保证web应用一直能正常运行&#xff0c;今天我们继续优化&#xff0…

为什么g++编译后的cpp文件名字为a,out

文章目录 为什么g编译后的cpp文件名字为a,out能修改默认名变成cpp文件名吗关于作者 为什么g编译后的cpp文件名字为a,out 在使用g编译C源代码时&#xff0c;默认情况下生成的可执行文件名为 a.out。这是由于在Unix和类Unix系统上&#xff0c;编译器的默认行为是将生成的可执行文…