LeetCode(Python)—— x的平方根(简单)

x的平方根

概述:给你一个非负整数 x ,计算并返回 x 的算术平方根 。由于返回类型是整数,结果只保留整数部分,小数部分将被舍去。注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 。

输入:x = 4
输出:2

输入:x = 8
输出:2

方法一:二分查找

思路:二分查找的下界为 0 ,上界可以粗略地设定为 x 。在二分查找的每一步中,我们只需要比较中间元素 mid 的平方与的大小关系,并通过比较的结果调整上下界的范围。由于我们所有的运算都是整数运算,不会存在误差,因此在得到最终的答案 ans 后,也就不需要再去尝试 ans+1 了。

# 二分查找
class Solution:
    def mySqrt(self, x: int) -> int:
        left = 0 # 下界
        right = x # 上界
        ans = -1 # 返回值
        while left <= right:
            mid = (left + right) // 2
            if mid * mid <= x:
                ans = mid
                left = mid + 1
            else:
                right = mid - 1
        return ans

方法二:牛顿迭代法

思路:牛顿迭代法的本质是借助泰勒级数,从初始值开始快速向零点逼近。我们选择 x0 = C 作为初始值。在进行 i 次迭代后,xi 的值与真实的零点 0.5 ** C 足够接近,即可作为答案。

# 牛顿迭代法
class Solution:
    def mySqrt(self, x: int) -> int:
        if x == 0:
            return 0
        c = x0 = float(x)
        while True:
            xi = 0.5 * (x0 + c / x0)
            if abs(x0 - x1) < 1e-7: # 1e-7为无穷小
                break
            x0 = xi
        return int(xi)

总结

牛顿,永远滴神!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值