位置: 编程技术 - 正文

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

  • 个人所得税查询工资与实际工资不符是为何
  • 我国增值税税率改革带来的影响
  • 企业如何代员工缴社保
  • 备案办税人员信息填本人的有风险吗
  • 建设工程劳务分包的规定
  • 饭店发光板图片大全
  • 商家发票可以随便开金额吗
  • 未确认融资费用计算公式
  • 高新技术企业发展现状
  • 房地产企业配套设施的核算内容
  • 支付给个人的佣金怎么做账务处理
  • 当月商品已出库货款未收到怎么做分录?
  • 企业代办业务有哪些
  • 行政单位在建工程入账
  • 一个公司只有一个财务人员,可以吗
  • 资产负债表年初余额是不是一直不变
  • 股票投资收益需要缴纳增值税吗
  • 没进项发票要交多少税
  • 无票费用如何做凭证分录
  • 对公账户每个月
  • 企业所得税季报是填累计数吗
  • 开红字冲红发票 下个月怎么申报
  • 累计折旧属于什么
  • 核定征收的个税怎么算
  • 社保费现金收缴管理制度
  • 怎么解决百度打不开页面
  • 计提本月应付的租金
  • 怎么安装win7系统u盘
  • linux命令行怎么用
  • 新版win10任务栏
  • 付款凭证怎么填写电脑
  • 年中建账年初余额怎么录入
  • php获取表单数据保存到mysql中
  • input 文件
  • 集成代码
  • 长期借款利息的账务处理涉及的会计科目有
  • 3d人体骨骼模型软件
  • 认缴制情况下 公司一定要出资到位再注销吗
  • 坏账的资产减值损失可以税前扣除吗
  • 注册资金到位时间填多少年最好
  • sQlite常用语句以及sQlite developer的使用与注册
  • 现金发放工资会计科目怎么写
  • 在建工程项目的范围包括
  • 所得税费用该怎么算
  • 经营户个人所得税
  • mysql的long类型
  • sql server2012使用方法
  • 新建厂房环评费会计科目
  • 利润表和资产负债表不平的原因
  • 一般纳税人增值税优惠政策2023
  • 融资租入固定资产的改建支出
  • 已确认收入但尚未发出商品分录
  • 劳务费入什么费用
  • 工程结算收入是否缴纳增值税
  • 购入投资性房地产支付的相关税费
  • 小规模纳税人购入固定资产怎么做账
  • 视同销售但未收到钱怎么做账?
  • 异地缴纳增值税和附加税的区别
  • 计提工资与实发工资有差额怎么计算成本
  • 事业单位预收账款
  • 工业企业生产什么
  • mysql参数表
  • sql存储过程实例详解
  • 如何查看网络连接密码
  • windows10怎么隐藏工具栏
  • xp系统与win7系统的电脑怎么组成局域网
  • rundll32.exe是病毒吗
  • rosnmgr.exe - rosnmgr是什么进程 有什么用
  • win10系统如何查找文件
  • javascript+css3开发打气球小游戏完整代码
  • 细说javascript
  • angular.js
  • angular keyup
  • nodejs拼接路径的方法
  • keycode输入cat
  • Android IntentService解析
  • java script教程
  • 税务稽查强制措施
  • 融资租赁公司购进车辆账务处理
  • 企业所得税率2023年
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设