python整数溢出问题_Python在处理大浮点数和整数时防止溢出错误

Python的整数是任意精度,因此如果使用交互算法计算斐波那契数列,则可以计算精确结果。

>>> def fib(n):

... a = 0

... b = 1

... while n > 0:

... a, b = b, a + b

... n = n - 1

... return a

...

>>> fib(100)

354224848179261915075LPython有几个多精度浮点库。 decimal模块包含在Python中,最初用于财务计算。它确实支持sqrt(),因此您可以执行以下操作:

>>> import decimal

>>> decimal.setcontext(decimal.Context(prec=40))

>>> a=decimal.Decimal(5).sqrt()

>>> a

Decimal('2.236067977499789696409173668731276235441')

>>> ((1+a)**100 - (1-a)**100)/(a*(2**100))

Decimal('354224848179261915075.0000000000000000041')其他库是mpmath和gmpy2。

>>> import gmpy2

>>> gmpy2.set_context(gmpy2.context(precision=150))

>>> a=gmpy2.sqrt(5)

>>> a

mpfr('2.2360679774997896964091736687312762354406183598',150)

>>> ((1+a)**100 - (1-a)**100)/(a*(2**100))

mpfr('354224848179261915075.00000000000000000000000248',150)

>>> gmpy2.fib(100)

mpz(354224848179261915075L)gmpy2也可以直接计算机斐波纳契数(如上图所示)。

免责声明:我维持gmpy2。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值