我试图通过计算整数的非常大的幂来打印一个非常大的数字。虽然我的代码是正确的,但我没有观察到所需的输出。
通常,python解释器可以打印非常大的整数,就像系统内存支持的那样。考虑到这个假设,下面是我正在运行的代码。
a = int(input())
b = int(input())
c = int(input())
d = int(input())
import math
if a in range(1,1001):
if b in range(1,1001):
if c in range(1,1001):
if d in range(1,1001):
print((math.pow(a,b)+math.pow(c,d)))
我观察到的输出是
4710194409608608302099333120
预期的输出是
4710194409608608369201743232
你能为我提供如何解决这个问题的指示吗? 输入值为:
a = 9
b = 29
c = 7
d = 27
您遇到了浮点精度的限制。从文档中:
与内置的 ** 运算符不同,math.pow(( 将两者转换为 用于键入浮点数的参数。使用 ** 或内置的 pow(( 函数 计算精确的整数幂。
所以只需使用**
>> 9**29+7**27
4710194409608608369201743232
math.pow
将输入转换为float
您显示的预期结果是您在执行以下操作时获得的结果:
x = 9**29
y = 7**27
print(x+y)
您看到的结果来自此:
x = float(9**29)
y = float(7**27)
print(int(x+y))
试试这样
>>> 9 ** 29 + 7 ** 27
4710194409608608369201743232