0

在使用 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

请解释发生了什么并提供帮助。

4

2 回答 2

2

使用整数除法而不是浮点数:

x //= 10
于 2014-12-09T19:05:58.140 回答
0

不知道您是否正在寻找替代实现,但如果您不想冒险进入浮点领域,这可能会更直接。

# Python 2.7
x = str(2**1000)
print sum([int(i) for i in x])
于 2014-12-09T19:08:48.663 回答