为什么我能';如果数字太小,例如pow(1e+;15+;1,1/3),则无法获得精度为float的python的正确答案
这是我的职责为什么我能';如果数字太小,例如pow(1e+;15+;1,1/3),则无法获得精度为float的python的正确答案,python,pow,Python,Pow,这是我的职责 def eformat(f, prec, exp_digits): s = "%.*e"%(prec, f) mantissa, exp = s.split('e') return "%se%+0*d"%(mantissa, exp_digits+1, int(exp)) n=int(input().strip()) l_test=[] for i in range(n): l_test.append(list
def eformat(f, prec, exp_digits):
s = "%.*e"%(prec, f)
mantissa, exp = s.split('e')
return "%se%+0*d"%(mantissa, exp_digits+1, int(exp))
n=int(input().strip())
l_test=[]
for i in range(n):
l_test.append(list(map(int,input().split())))
def fonc(l,r,k):
res=0
for i in range(l,r+1):
r1=10**(-k)
print(r1)
res+=(i+(r1))**(1/3)-i**(1/3)
return res
for i in range(n):
l,r,k=l_test[i]
res=fonc(l,r,k)`enter code here`
print(eformat(res,5,3))
输入1/n 11 15,正确答案应为3.3333E+016尝试使用decimal.decimal-结果是否更好?您的大部分代码似乎与您的问题无关。你能把它减少到最低限度吗?你应该小心地把非常小的数字加到非常大的数字上。双精度仅保留16位小数。1e15+1返回正确,但请注意,这已接近极限。就python而言,1e16+1==1e16。感谢您的回答,它在使用十进制后工作。