Python计算开方、立方、圆周率,精确到小数点后任意位的方法


Posted in Python onJuly 17, 2018

Python计算的位数

在电脑上做了一个实验,看看python能计算到多少位,一下是结果。

x = math.sqrt((3))
print ("%.53f"%(x))
print ("%.63f"%(x))
print ("%.83f"%(x))
1.73205080756887719317660412343684583902359008789062500
1.732050807568877193176604123436845839023590087890625000000000000
1.73205080756887719317660412343684583902359008789062500000000000000000000000000000000
1.73205080756887719317660412343684583902359008789062500000000000000000000000000000000

计算立方根公式

设A = X^3,求X.称为开立方。 开立方有一个标准的公式:

Python计算开方、立方、圆周率,精确到小数点后任意位的方法

例如,A=5,,即求5介于1的3次方至2的3次方之间(1的3次方=1,2的3次方=8)

初始值X0可以取1.1,1.2,1.3,1.4,1.5,1.6,1.7,1.8,1.9,都可以。例如我们取X0 = 1.9按照公式:

第一步:X1=1.9+(5/1.9²-1.9)1/3=1.7;

即5/1.9×1.9=1.3850416,1.3850416-1.9=-0.5149584,-0.5149584×1/3=-0.1716528,1.9+(-0.1716528)=1.7。即取2位数值,,即1.7。

第二步:X2=1.7+(5/1.7²-1.7)1/3=1.71;

即5/1.7×1.7=1.73010,1.73-1.7=0.03,0.03×1/3=0.01,1.7+0.01=1.71。取3位数,比前面多取一位数。

第三步:X3=1.71+(5/1.71²-1.71)1/3=1.709;

第四步:X4=1.709+(5/1.709²-1.709)1/3=1.7099;

这种方法可以自动调节,第一步与第三步取值偏大,但是计算出来以后输出值会自动转小;第二步,第四步输入值偏小,输出值自动转大。即5=1.7099³ 当然初始值X0也可以取1.1,1.2,1.3,。。。1.8,1.9中的任何一个,都是X1 = 1.7 。当然,我们在实际中初始值最好采用中间值,即1.5。 1.5+(5/1.5²-1.5)1/3=1.7。

增加计算步骤,可以得到任意精度的值

计算根号2任意位数

开平方公式

如果用这个公式开平方,只需将3改成2,2改成1。即

Python计算开方、立方、圆周率,精确到小数点后任意位的方法

import sys
n = 2
s = 0
while True:
 for si in range(9,-1,-1):
 nx = n - ((2*s*10+si)*si)
 if nx>=0:
  s = s*10+si
  n = nx*100
  sys.stdout.write(str(si))
  sys.stdout.flush()
  break

计算开5次方公式,精确至任意位数

Python计算开方、立方、圆周率,精确到小数点后任意位的方法

计算圆周率任意位数

因为根据马青公式π/4=4arctg1/5-arctg1/239

又因为arctgX=X-(1/3)X^3+(1/5)X^5-(1/7)X^7+……+[(-1)^(n-1)/((2n-1)]*X^(2n-1))

变形得π/4=(4/5-1/239)-1/3(4/5^3-1/239^3)+1/5(4/5^5-1/239^5)……

所以可以用python语言编写出求圆周率到任意位的程序如下:

n = int(raw_input('请键入想要计算到小数点后的位数n:')) #先键入字符串,再转化为整数

w = n+10 #多计算10位,防止尾数取舍的影响

b = 10**w #算到小数点后w位

x1 = b*4//5 #求含4/5的首项

x2 = b// -239 #求含1/239的首项

he = x1+x2 #求第一大项

n *= 2 #设置下面循环的终点,即共计算n项

for i in xrange(3,n,2): #循环初值=3,末值2n,步长=2

x1 //= -25 #求每个含1/5的项及符号

x2 //= -57121 #求每个含1/239的项及符号

x = (x1+x2) // i #求两项之和

he += x #求总和

pai = he*4 #求出π

pai //= 10**10 #舍掉后十位

print pai #输出圆周率π的值,

以上这篇Python计算开方、立方、圆周率,精确到小数点后任意位的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python使用新浪微博api上传图片到微博示例
Jan 10 Python
python使用htmllib分析网页内容的方法
May 08 Python
python的格式化输出(format,%)实例详解
Jun 01 Python
Python在for循环中更改list值的方法【推荐】
Aug 17 Python
Pycharm取消py脚本中SQL识别的方法
Nov 29 Python
python3在同一行内输入n个数并用列表保存的例子
Jul 20 Python
TensorFlow车牌识别完整版代码(含车牌数据集)
Aug 05 Python
python logging日志模块原理及操作解析
Oct 12 Python
如何用OpenCV -python3实现视频物体追踪
Dec 04 Python
谈谈Python:为什么类中的私有属性可以在外部赋值并访问
Mar 05 Python
基于python获取本地时间并转换时间戳和日期格式
Oct 27 Python
教你怎么用Python selenium操作浏览器对象的基础API
Jun 23 Python
python把数组中的数字每行打印3个并保存在文档中的方法
Jul 17 #Python
python3.x 将byte转成字符串的方法
Jul 17 #Python
Python 字符串转换为整形和浮点类型的方法
Jul 17 #Python
Python操作word常见方法示例【win32com与docx模块】
Jul 17 #Python
python查看列的唯一值方法
Jul 17 #Python
Python使用win32com模块实现数据库表结构自动生成word表格的方法
Jul 17 #Python
python 数字类型和字符串类型的相互转换实例
Jul 17 #Python
You might like
php判断字符以及字符串的包含方法属性
2008/08/30 PHP
php 移除数组重复元素的一点说明
2008/11/27 PHP
Yii查询生成器(Query Builder)用法实例教程
2014/09/04 PHP
smarty简单入门实例
2014/11/28 PHP
PHP ADODB实现事务处理功能示例
2018/05/25 PHP
实例:尽可能写友好的Javascript代码
2006/10/09 Javascript
在vs2010中调试javascript代码方法
2011/02/11 Javascript
基于JQUERY的两个ListBox子项互相调整的实现代码
2011/05/07 Javascript
jQuery学习笔记之jQuery.fn.init()的参数分析
2014/06/09 Javascript
详解js中构造流程图的核心技术JsPlumb(2)
2015/12/08 Javascript
Jquery on方法绑定事件后执行多次的解决方法
2016/06/02 Javascript
值得分享的JavaScript实现图片轮播组件
2016/11/21 Javascript
jQuery Easyui加载表格出错时在表格中间显示自定义的提示内容
2016/12/08 Javascript
JS实现移动端按首字母检索城市列表附源码下载
2017/07/05 Javascript
vue 自定义组件 v-model双向绑定、 父子组件同步通信的多种写法
2017/11/27 Javascript
vue scroller返回页面记住滚动位置的实例代码
2018/01/29 Javascript
解决Vue.js父组件$on无法监听子组件$emit触发事件的问题
2018/09/12 Javascript
angular学习之动态创建表单的方法
2018/12/07 Javascript
Egg Vue SSR 服务端渲染数据请求与asyncData
2019/11/24 Javascript
解决vue初始化项目一直停在downloading template的问题
2020/11/09 Javascript
keep-alive保持组件状态的方法
2020/12/02 Javascript
[01:28:56]2014 DOTA2华西杯精英邀请赛 5 24 CIS VS DK
2014/05/26 DOTA
python通过imaplib模块读取gmail里邮件的方法
2015/05/08 Python
Python和C/C++交互的几种方法总结
2017/05/11 Python
Python探索之自定义实现线程池
2017/10/27 Python
Python序列循环移位的3种方法推荐
2018/04/09 Python
Opencv+Python 色彩通道拆分及合并的示例
2018/12/08 Python
python实现飞机大战游戏
2020/10/26 Python
Python hashlib模块实例使用详解
2019/12/24 Python
Pytorch模型转onnx模型实例
2020/01/15 Python
数字天堂软件测试面试题
2012/12/23 面试题
这76道Java面试题及答案,祝你能成功通过面试
2016/04/16 面试题
担保书怎么写
2014/04/01 职场文书
会计专业求职信范文
2015/03/19 职场文书
HTML+VUE分页实现炫酷物联网大屏功能
2021/05/27 Vue.js
vue实现拖拽交换位置
2022/04/07 Vue.js