位置: 编程技术 - 正文

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数据可视化课后题答案)

  • 财产转让所得个人所得税优惠政策
  • 进项税额抵扣计算
  • 货物运费包含哪些项目
  • 讲师讲课费标准2019
  • 股东参与经营可以分红吗
  • 销售自己使用过的固定资产如何开票
  • 固定资产公允价值减去处置费用后的净额
  • 外币账户收款如何做账务处理呢?
  • 资本公积的核算内容不包括
  • 已经认证的进项税转出
  • 库存现金存入银行怎么记账
  • 收到原未计入应收项目的交易性金融资产的利息
  • 电子承兑必须对账吗
  • 购买软件的增值税可以抵扣吗
  • 所得税季报固定资产加速折旧表资产原值
  • 企业盈利计提所得税么?
  • 营改增前的工程款现在怎么开票
  • 进项税额抵扣的情况有哪些
  • 企业发生的销售折让
  • 职工向公司借款计入什么科目
  • 现金流量表编制依据和方法
  • 酒店的床和沙发哪个好
  • 公司投资股票要交什么税
  • 股票怎么算印花税收入
  • 外贸企业进项税额
  • 受托加工物资算资产吗
  • 电子税务局财报怎么报
  • 应收和预收怎么算
  • 发票收到本月进账怎么办
  • 全额抵免的计算
  • 什么是财政代管资金
  • 个体工商税务登记需要费用
  • 收到折扣发票怎么处理
  • 水电费无发票如何做账
  • 苹果屏幕刷新率120hz的机型
  • 如何让windows8.1更流畅
  • mac系统存储好大
  • 蜻蜓翅膀特写怎么画
  • php编写网站
  • 非货币性资产交换补价大于25%的会计处理
  • phpinfo()中Loaded Configuration File(none)的解决方法
  • framework在哪里打开
  • 消费税会计分录怎么做的
  • css定位属性的运用
  • opencv官方教程
  • python中模块的用法
  • 合伙企业退伙如何缴纳个人所得税
  • Packaging a Qt application
  • 金蝶固定资产折旧调整
  • sqlserver有实例吗
  • 小规模企业主营业务成本分录
  • 小规模纳税人为什么不能抵扣进项税
  • 有限公司股权转让需要股东会决议吗
  • 可抵扣的进项税额要减去进项转出吗
  • 注册资本一般为多少
  • 融资租赁固定资产不属于筹资活动
  • 被工商吊销营业执照怎么办
  • 购车预付款交了可以退吗
  • 营业收入怎么确定
  • 建筑公司租赁费会计分录
  • 年数总和法净残值怎么算
  • win8系统如何关机
  • 如何关闭windows8的密码
  • 微软推送win10更新 蓝牙
  • ubuntu邮箱客户端
  • win7系统打开软件慢的原因
  • win10系统如何给d盘加密
  • sysscjh.exe是什么文件
  • windows1021h2镜像下载
  • win10 2020h1
  • win7如何限制网速
  • javascript语言基础
  • cocos2d-x教程
  • linux用户放在哪个目录
  • shell(bash)下“time” 命令的输出详解
  • jquery悬浮窗
  • jQuery插件库
  • 简述shell命令提示符的组成
  • 税务实地核实工作程序
  • 加油的增值税发票可以抵扣吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设