在使用Python解决Project Euler问题时(我是初学者),我遇到了以下错误。问题是要找到2 ^ 1000的数字之和。为此,我写了以下代码:
sum=0
x=2**1000
while(x):
sum += x%10
print(sum) #Just to check whats happening
x /= 10
print("\n"*5)
print("Sum = ",sum)
为此,我在中间的某处添加小数。
输出:
6
10.0
10.0
12.0
16.0
....
1116.0
1122.0
1131.625 #Why does the decimal get added?
1138.59375
.....
1181.495136589947
1186.5812084526442
1188.089815638914
1195.240676357541
1195.9557624294036
1197.0272710365898
1197.1344218973084
1197.1451369833803
1197.1462084919874
.....
1197.1463275484991 #This number gets repeated a lot of times
1197.1463275484991
1197.1463275484991
Sum = 1197.1463275484991
请解释发生了什么,并提供帮助。
答案 0 :(得分:2)
使用整数除法而不是浮点:
x //= 10
答案 1 :(得分:0)
不知道您是否正在寻找替代实施方案,但如果您不想冒险进入浮点土地,这可能会更直接。
# Python 2.7
x = str(2**1000)
print sum([int(i) for i in x])