Python用二分法求平方根的案例

下面是详细的Python用二分法求平方根的攻略。

算法思路

  1. 选择一个左端点 left 和一个右端点 right(可以是任意两个正数,满足 left * left < num < right * right),并计算它们的中点 mid = (left + right) / 2
  2. 如果 mid * mid == num,则 mid 就是 num 的平方根。
  3. 如果 mid * mid < num,则说明 mid 比平方根小,那么平方根应该在 mid 右侧,此时更新 leftmid
  4. 如果 mid * mid > num,则说明 mid 比平方根大,那么平方根应该在 mid 左侧,此时更新 rightmid
  5. 不断重复步骤2~4,直到 leftright 越来越接近,即 right - left < 1e-7

代码实现

下面是Python代码实现:

def sqrt(num: float) -> float:
    left, right = 0, num
    while right - left > 1e-7:
        mid = (left + right) / 2
        if mid * mid < num:
            left = mid
        else:
            right = mid
    return left

函数 sqrt 的输入参数为要求平方根的数字 num,返回值为 num 的平方根。参数 num 必须为非负实数。

例如,求解 4 的平方根,可调用函数:

sqrt(4)  # 返回 2.0

再例如,求解 2 的平方根(结果保留6位小数),可调用函数:

round(sqrt(2), 6)  # 返回 1.414214

总结

二分法是一种求解函数零点(或极值)的重要方法,可用于求解广义上的平方根、立方根等多种根号形式的问题。但注意在二分时要注意边界,并且要使用浮点数进行计算,以免出现无限循环的情况。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Python用二分法求平方根的案例 - Python技术站

(0)
上一篇 2023年6月3日
下一篇 2023年6月3日

相关文章

  • 如何在Python中进行多变量正态性测试

    在Python中进行多变量正态性测试,可以使用多种方法,包括使用统计模块scipy.stats中的shapiro函数和它的变体,以及使用矩阵特征值分解等方法。以下是其中两种方法的示例: 方法一:使用shapiro函数进行多变量正态性测试 使用scipy.stats中的shapiro函数,可以测试多个变量是否满足正态分布。下面是一个示例,它使用一个2×3的数据…

    python-answer 2023年3月25日
    00
  • Python字符串拼接六种方法介绍

    Python字符串拼接六种方法介绍 在Python编程中,字符串拼接是基础且常用的操作,本攻略将介绍六种不同的字符串拼接方法,适用于不同的场景和需求。 1. 直接使用+拼接 直接使用+号连接多个字符串,可以简单快捷地完成字符串拼接操作。 示例代码如下: str1 = "hello" str2 = "world" res…

    python 2023年6月5日
    00
  • 无法使用 Matplotlib – Ubuntu 10.10 和 Python 3.2

    【问题标题】:Unable to use Matplotlib – Ubuntu 10.10 and Python 3.2无法使用 Matplotlib – Ubuntu 10.10 和 Python 3.2 【发布时间】:2023-04-07 21:29:01 【问题描述】: 我在 Ubuntu 10.10 i386(32 位)上运行 python3.2。…

    Python开发 2023年4月8日
    00
  • python如何实现常用的五种排序算法详解

    下面是关于“Python实现常用的五种排序算法详解”的完整攻略。 1. 排序算法理论基础 排序算法是一种常用的算法,它可以一组数据按照一定的规则进行排序。常用的排序算法有五种,分别是冒泡排序、选择排序、插入排序、速排序和归并排序。 1.1 冒泡排序 冒泡排序是一种简单的排序算法,它的基本思想是通过邻元素之间的较和交换来实现排序。具体实现过程是从第一个元素开始…

    python 2023年5月13日
    00
  • Selenium常见异常解析及解决方案示范

    Selenium常见异常解析及解决方案示范 1. 作用 Selenium是一个自动化测试工具,也可被用于Web服务的应用程序的功能测试。本文将详细讲解在使用Selenium时,遇到的常见的异常以及解决方案,希望能够帮助到大家。 2. 常见异常 2.1. NoSuchElementException 异常 问题描述: 在WebDriver执行元素的定位操作时,…

    python 2023年5月13日
    00
  • Python 保持递归形式

    Python 保持递归形式指通过使用尾递归和循环等技巧,使得递归函数的调用栈得以不断被压缩,从而可以最大程度地避免递归调用过深而导致的栈溢出等问题。下面将详细介绍如何保持递归形式的使用方法: 尾递归优化 尾递归指的是递归函数在调用自身后直接返回结果,不再对返回结果进行任何额外的处理,从而$渐进地消除每个递归调用。(这里的“渐进”指的是最终递归次数将到达一个恒…

    python-answer 2023年3月25日
    00
  • Python基础学习之基本数据结构详解【数字、字符串、列表、元组、集合、字典】

    Python基础学习之基本数据结构详解 Python数据类型 在Python中,一共有几种基本的数据类型: 数字(Number):整数,浮点数 字符串(String):用于表达文本信息 列表(List):用于存储一系列有序的元素 元组(Tuple):与列表类似,但是元素不可修改 集合(Set):用于存储一系列无序的元素(不能含有重复元素) 字典(Dictio…

    python 2023年5月13日
    00
  • 使用科大讯飞语音SDK实现文字在线合成语音

    使用科大讯飞语音SDK实现文字在线合成语音需要进行以下步骤: 步骤1:注册和申请应用 首先,前往科大讯飞官网(http://www.xfyun.cn/)进行注册,并创建应用,获取AppID。 步骤2:下载SDK 下载语音合成SDK,SDK支持Windows、Linux、Android平台,具体的下载方式可参考官网:http://www.xfyun.cn/se…

    python 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部