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

yizhihongxing

下面是详细的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日

相关文章

  • pygame实现俄罗斯方块游戏(基础篇1)

    下面我详细讲解“pygame实现俄罗斯方块游戏(基础篇1)”的完整攻略。 攻略概述 这是一篇关于使用pygame模块实现经典俄罗斯方块游戏的教程,主要讲解如何搭建游戏窗口,绘制俄罗斯方块和移动俄罗斯方块等游戏元素的基础知识。 攻略分为以下几个部分: pygame安装及环境配置 搭建游戏的主窗口 绘制静态元素:游戏背景、网格和方块形状 实现方块的下落和移动 p…

    python 2023年6月5日
    00
  • python构建基础的爬虫教学

    Python构建基础的爬虫教学 概述 爬虫是一种自动化抓取网页数据的程序,可以帮助我们快速获取海量数据。Python作为一种易于学习、简洁明了、功能齐全的编程语言,是非常适用于构建爬虫应用的语言。在本篇教程中,我们将介绍Python构建基础的爬虫应用的入门知识,包括Python爬虫的基本原理、库的使用以及实战案例。 基本原理 Python爬虫的基本原理是通过…

    python 2023年5月14日
    00
  • python爬虫爬取图片的简单代码

    下面是关于”python爬虫爬取图片的简单代码”的完整攻略和示例说明: 什么是Python爬虫? Python爬虫是指使用Python编写程序,自动化地从网站抓取数据。Python爬虫是一种非常强大的工具,使用它,可以快速地获取大量的数据。 如何使用Python爬虫抓取图片? 爬取图片的过程和爬取普通的文本信息的过程大体相似,只是需要使用不同的方法来下载和处…

    python 2023年5月14日
    00
  • Python办公自动化从Excel中计算整理数据并写入Word

    以下是Python办公自动化从Excel中计算整理数据并写入Word的完整实例教程。 目录 准备工作 读取Excel数据 计算Excel数据 整理数据并写入Word 完整代码 准备工作 在开始编写这个自动化脚本之前,我们需要安装两个依赖库xlrd和python-docx用于处理Excel和Word文件。 pip install xlrd python-doc…

    python 2023年5月13日
    00
  • Python中常用数据类型使用示例概括总结

    以下是“Python中常用数据类型使用示例概括总结”的完整攻略。 1. Python中常用的数据类型 在Python中常用的数据类型包括整数、浮点数、字符串、列表、元组、字典和集合等。以下是这些数据类型的简要介绍: 整数:表示整数,例如1、2、3等。 浮点数:表示带有小数点的数,例如1.0、2.5、3.14等。 字符串:表示文本,例如”hello””worl…

    python 2023年5月13日
    00
  • python任务调度实例分析

    关于python任务调度的实例分析,我可以为您提供以下的完整攻略: Python任务调度实例分析 什么是任务调度 任务调度是指按照一定的规则和时间安排系统中需要完成的各种任务和作业,使系统正确、高效地运行,提高系统的可靠性和稳定性。 常见的任务调度器有crontab和atd,但Python也提供了灵活的任务调度机制。通常情况下,我们可以使用Python标准库…

    python 2023年5月19日
    00
  • 基于python实现井字棋小游戏

    基于python实现井字棋小游戏完整攻略 1. 概述 本攻略将指导您如何使用python编写一个简单的井字棋小游戏。 2. 准备工作 在编写本游戏前,您需要安装Python 3,并安装该游戏所需的库,其中包括: tkinter: 用于创建游戏图形界面 Pillow: 用于对图形进行处理 您可以使用以下命令安装这些库: pip install tkinter …

    python 2023年5月19日
    00
  • 基于python修改srt字幕的时间轴

    基于python修改srt字幕的时间轴,可以通过以下几个步骤完成: 1. 读取SRT文件 使用Python中的open()方法,打开要修改的SRT文件,读取其内容,并存储在一个变量中。代码如下: with open(‘subtitle.srt’, ‘r’, encoding=’utf-8′) as f: content = f.read() 2. 更改时间轴…

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