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

相关文章

随想录 Day 69 并查集 107. 寻找存在的路径

随想录 Day 69 并查集 107. 寻找存在的路径 理论基础 int n = 1005; // n根据题目中节点数量而定,一般比节点数量大一点就好vector<int> father = vector<int> (n, 0); // C++里的一种数组结构// 并查集初始化void init() {for (int i = 0; i < n; ++i) {father[i] = i;}

Python 字符串占位

在Python中,可以使用字符串的格式化方法来实现字符串的占位。常见的方法有百分号操作符 % 以及 str.format() 方法 百分号操作符 % name = "张三"age = 20message = "我叫%s,今年%d岁。" % (name, age)print(message) # 我叫张三,今年20岁。 str.format() 方法 name = "张三"age

一道经典Python程序样例带你飞速掌握Python的字典和列表

Python中的列表(list)和字典(dict)是两种常用的数据结构,它们在数据组织和存储方面有很大的不同。 列表(List) 列表是Python中的一种有序集合,可以随时添加和删除其中的元素。列表中的元素可以是任何数据类型,包括数字、字符串、其他列表等。列表使用方括号[]表示,元素之间用逗号,分隔。 定义和使用 # 定义一个列表 fruits = ['apple', 'banana

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

python 喷泉码

因为要完成毕业设计,毕业设计做的是数据分发与传输的东西。在网络中数据容易丢失,所以我用fountain code做所发送数据包的数据恢复。fountain code属于有限域编码的一部分,有很广泛的应用。 我们日常生活中使用的二维码,就用到foutain code做数据恢复。你遮住二维码的四分之一,用手机的相机也照样能识别。你遮住的四分之一就相当于丢失的数据包。 为了实现并理解foutain

python 点滴学

1 python 里面tuple是无法改变的 tuple = (1,),计算tuple里面只有一个元素,也要加上逗号 2  1 毕业论文改 2 leetcode第一题做出来

Python爬虫-贝壳新房

前言 本文是该专栏的第32篇,后面会持续分享python爬虫干货知识,记得关注。 本文以某房网为例,如下图所示,采集对应城市的新房房源数据。具体实现思路和详细逻辑,笔者将在正文结合完整代码进行详细介绍。接下来,跟着笔者直接往下看正文详细内容。(附带完整代码) 正文 地址:aHR0cHM6Ly93aC5mYW5nLmtlLmNvbS9sb3VwYW4v 目标:采集对应城市的

python 在pycharm下能导入外面的模块,到terminal下就不能导入

项目结构如下,在ic2ctw.py 中导入util,在pycharm下不报错,但是到terminal下运行报错  File "deal_data/ic2ctw.py", line 3, in <module>     import util 解决方案: 暂时方案:在终端下:export PYTHONPATH=/Users/fujingling/PycharmProjects/PSENe

LeetCode--231 2的幂

题目 给定一个整数,编写一个函数来判断它是否是 2 的幂次方。 示例 示例 1:输入: 1输出: true解释: 20 = 1示例 2:输入: 16输出: true解释: 24 = 16示例 3:输入: 218输出: false class Solution {public:bool isPowerOfTwo(int n) {if (n <= 0) return fals