2013-04-17 14:34:39 +08:00

33 lines
810 B
Python

''' An irrational decimal fraction is created by concatenating the positive
integers:
0.123456789101112131415161718192021...
It can be seen that the 12th digit of the fractional part is 1.
If dn represents the nth digit of the fractional part, find the value of the following expression.
d1 * d10 * d100 * d1000 * d10000 * d100000 * d1000000 '''
from math import log10
def num(x, i):
if i > int(log10(x)):
raise IOError
else:
i = int(log10(x)) - i
while i > 0:
x /= 10
i -= 1
return x % 10
def d(x):
elem = [0, 9, 189, 2889, 38889, 488889, 5888889, 68888889]
for i in xrange(len(elem)):
if elem[i] >= x:
break
x -= elem[i - 1] + 1
return num(10 ** (i - 1) + x / i, x % i)
multi = 1
for i in xrange(7):
multi *= d(10 ** i)
#print d(10 ** i)
print multi