位置: 编程技术 - 正文

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

  • 出租房屋收取水电费 能计收入吗
  • 递延所得税负债计算公式
  • 个体工商户要报工商年报吗?
  • 法人向公司账户汇款怎么做账
  • 应付账款赊销率和周转率的区别
  • 购进货物的发票是外来凭证吗
  • 个税退税是公司退还是个人退
  • 幼儿园伙食收支盈亏比例
  • 常见的税收优惠
  • 票据贴现业务利润怎么算
  • 限制性股票科目
  • 小企业固定资产折旧方法
  • 专利技术评估价值入股价偏高说明什么
  • 增值税普票跨月怎么冲红
  • 收到利息计入哪个会计科目
  • 进项税额一直大于销项税额
  • 促销服务费能抵增值税吗
  • 出口企业增值税税负率
  • 出口企业免抵增值税
  • 电商平台名称怎么注册
  • 收到加盟费尾款怎么做分录?
  • 设备升级改造如何开发票
  • 收到安装费发票怎么做分录
  • 运输费未取得运输专用发票怎么抵扣?
  • 资本资产定价模型
  • 代持的股份
  • 收到工伤保险的发票
  • 虚拟股份分红
  • 我想看一下这个月几日
  • win11 zen3
  • mac符号在哪里
  • 服务佣金是什么意思
  • 公司买的理财产品怎么做账
  • linux 查看文件内容 转换字符编码
  • 电脑上fci是什么文件
  • 代购机票骗局
  • 委托加工业务的组成计税价格
  • react connect用法
  • phpqrcode
  • vuex model
  • php zmq
  • 月底结转汇兑损益
  • laravel入门与实战:构建主流php应用开发框架
  • 什么叫非侵入性装置
  • 汇算清缴补交所得税怎么做凭证
  • 个体工商户没有收入要交税吗
  • 逆回购划算吗
  • 将房产以股权形式出售
  • 增值税减免税在贷方
  • 用友u8财务报表打印设置在哪
  • Linux编译mssql扩展使用php连接sqlserver2008的使用步骤
  • mysql分片sql
  • 纳税人可以享受六项专项附加扣除
  • 贴现凭证的分录
  • 小规模纳税人的税率是多少
  • 福利用什么表示
  • 土地转让需要批准吗
  • 没收到发票也可以入账吗
  • 融资租赁租金会计科目
  • 停车发票怎么盖章
  • 库存现金的主要活动
  • 天猫佣金是啥
  • 软件测试费用明细
  • 应付利润属于什么科目类别
  • 总帐设置在哪
  • mysql优化配置文件
  • mysql5.5怎么用
  • 简单基是什么
  • qq8.2.1版本下载正式版
  • 2008r2多用户远程桌面
  • 抢先体验的游戏可以退款吗
  • windows7使用
  • 在linux系统中,用来存在系统所需
  • u盘备份系统操作步骤
  • unity2019图集
  • googlevoice使用教程
  • 以划拨方式取得的土地使用权
  • 土地使用税申报流程图
  • 正外部性与负外部性的定义
  • 请问在哪里可以看到
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设