为什么我能';如果数字太小,例如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。感谢您的回答,它在使用十进制后工作。