-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy path074.py
executable file
·50 lines (37 loc) · 1.34 KB
/
074.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#!/usr/bin/python
# -*- coding: utf-8 -*-
#The number 145 is well known for the property that the sum of the factorial of its digits is equal to 145:
#1! + 4! + 5! = 1 + 24 + 120 = 145
#Perhaps less well known is 169, in that it produces the longest chain of numbers that link back to 169; it turns out that there are only three such loops that exist:
#169 → 363601 → 1454 → 169
#871 → 45361 → 871
#872 → 45362 → 872
#It is not difficult to prove that EVERY starting number will eventually get stuck in a loop. For example,
#69 → 363600 → 1454 → 169 → 363601 (→ 1454)
#78 → 45360 → 871 → 45361 (→ 871)
#540 → 145 (→ 145)
#Starting with 69 produces a chain of five non-repeating terms, but the longest non-repeating chain with a starting number below one million is sixty terms.
#How many chains, with a starting number below one million, contain exactly sixty non-repeating terms?
#Answer:
#402
from time import time; t=time()
from mathplus import factorial
M = 1000000
MM = 2177282
L = 60
fact = [factorial(n) for n in range(10)]
facts = [0]*MM
facts[:10] = fact[:]
for n in range(10, MM):
facts[n] = facts[n//10]+fact[n%10]
#print time()-t
ss = 0
for n in range(M):
m = n
way = {}
while m not in way:
way[m] = 1
m = facts[m]
if len(way) == 60:
ss += 1
print(ss)#, time()-t