位置: 编程技术 - 正文

Python编程实现二分法和牛顿迭代法求平方根代码(python erf)

编辑:rootadmin

推荐整理分享Python编程实现二分法和牛顿迭代法求平方根代码(python erf),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python2//4,python2ide,python 2to3,python2ide,python2怎么用,python 2,python 2to3,python 2to3,内容如对您有帮助,希望把文章链接给更多的朋友!

求一个数的平方根函数sqrt(int num) ,在大多数语言中都提供实现。那么要求一个数的平方根,是怎么实现的呢?实际上求平方根的算法方法主要有两种:二分法(binary search)和牛顿迭代法(Newton iteration)

1:二分法

求根号5

a:折半: 5/2=2.5b:平方校验: 2.5*2.5=6.>5,并且得到当前上限2.5c:再次向下折半:2.5/2=1.d:平方校验:1.*1.=1.<5,得到当前下限1.e:再次折半:2.5-(2.5-1.)/2=1.f:平方校验:1.*1.=3.<5,得到当前下限1.

每次得到当前值和5进行比较,并且记下下下限和上限,依次迭代,逐渐逼近平方根:

运行结果:1 2. 1. 1. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2. 2...[Finished in 0.1s]

经过次二分法迭代,得到的值和系统sqrt()差别在0.,精度在亿分之一,

0.需要迭代8次

因此,在对精度要求不高的情况下,二分法也算比较高效的算法。

2:牛顿迭代

仔细思考一下就能发现,我们需要解决的问题可以简单化理解。

从函数意义上理解:我们是要求函数f(x)=x²,使f(x)=num的近似解,即x²-num=0的近似解。

Python编程实现二分法和牛顿迭代法求平方根代码(python erf)

从几何意义上理解:我们是要求抛物线g(x)=x²-num与x轴交点(g(x)=0)最接近的点。

我们假设g(x0)=0,即x0是正解,那么我们要做的就是让近似解x不断逼近x0,这是函数导数的定义:

可以由此得到

从几何图形上看,因为导数是切线,通过不断迭代,导数与x轴的交点会不断逼近x0。

对于一般情况:

将m=2代入:

运行结果:1 2. 2. 2...

精确到亿分之一,牛顿法只迭代了3次,是二分法的十倍

3:利用牛顿法求开立方

微积分、概率、线代是高级算法的基础课。可是,这么多年,已经忘得差不多了..............................

总结

标签: python erf

本文链接地址:https://www.jiuchutong.com/biancheng/377056.html 转载请保留说明!

上一篇:Python编程给numpy矩阵添加一列方法示例(Python编程给定a=1,b=4,输出a+b的值)

下一篇:Python数据可视化正态分布简单分析及实现代码(python数据可视化课后题答案)

  • 个人所得税可以退吗
  • 消费税计算时的进项税额
  • 应税劳务销售额怎么算
  • 赠与税是什么税种
  • 品种法,分批法,分步法是什么
  • 国库券利息收入计入利润总额吗
  • 筹建期间发生的开办费计入什么科目
  • 发现之前的差旅费补助多报了一天该怎么调整
  • 新企业需要结转增值税吗
  • 营改增医院增值税
  • 未计提坏账准备金额在哪个科目
  • 转让五年以上住房免征个人所得税吗?
  • 营改增后小规模纳税人税率是多少
  • 三证合一办完后的流程
  • 总分机构如何做账
  • 期初数据科目期初余额怎么录入?
  • 理财代持有法律效力吗
  • 忘了结转成本怎么办
  • 企业贷款利息是否可以提前还款
  • 工会财务总结报告
  • 专家费收取多少合适
  • 装修费怎么摊销,租期两年
  • 收到别人的文章或书,应该怎样表示
  • linux对硬件的要求
  • 转让金融商品应交增值税怎么算
  • mac如何连接电脑
  • 广告业财政拨款包括哪些
  • 筹建期固定资产汇算清缴
  • 微信获取用户id失败如何解决
  • 哪些发票内容可以抵税
  • PHP:ftp_get_option()的用法_FTP函数
  • 核准类减免税有哪些项目
  • 电脑显示语言栏在哪里
  • 花卉绿萝的养殖方法
  • phpget方法
  • flex布局子元素height100
  • PHP:date_sunrise()的用法_Date Time函数
  • 投标须知所包括的内容有哪些
  • PyTorch 深度学习实战 |用 TensorFlow 训练神经网络
  • 小规模拍卖公司怎么开票
  • 微调是调哪里
  • 公司是否可以开具在职证明
  • windows history命令
  • 未分配利润是负数是亏损吗
  • 土地增值税的相关问题
  • mysql备份方式有哪些
  • sqlserver sid
  • 应付职工薪酬中的职工是指
  • 费用分割单使用范围
  • 企业的净资产包括固定资产吗
  • sql语句批量添加数据
  • 品种法的特点有( )
  • 什么样的纳税人属于小规模纳税人
  • 结转本月完工产品成本会计分录怎么写
  • 固定资产未提完折旧
  • 如何收信用卡付款
  • 计提工会经费的会计分录
  • 长期借款和长期贷款一样吗
  • 怎么看发票的凭证号
  • 待处理财产损益的账务处理
  • 注册公司的流程及费用标准
  • 资产质量的相对性举例说明
  • 史上最全的mysql基础教程
  • windows提升性能
  • bios密码忘记了要怎么重置
  • ubuntu18 设置静态ip
  • windows8.1rt
  • unix2dos命令
  • django框架mvt
  • 置顶的朋友圈屏蔽的人能看到吗
  • jquery模拟表单提交
  • shell命令怎么用
  • android隐藏
  • python xml.etree.ElementTree遍历xml所有节点实例详解
  • java教程csdn
  • JavaScript中的复杂数据类型又称为
  • javascript面向
  • 用python编写的程序称为
  • 湖北电子网上税务怎么交
  • 广西发票查询平台
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设