использование списков:
Код: Выделить всё
n=100000
num=[]
suma=0
for i in range(n,1,-1):
tmp=tuple(set([n for n in factors(i)]))
if len(tmp) != 2: continue
if tmp not in num:
num.append(tmp)
suma+=i
Код: Выделить всё
n=100000
num={}
suma=0
for i in range(n,1,-1):
tmp=tuple(set([n for n in factors(i)]))
if len(tmp) != 2: continue
if tmp not in num:
num[tmp]=i
suma+=i
Я тестировал эти два кода, используя n=1000000, и первый код выполнялся за 1032 секунды, а второй — всего за 3,3 секунды, потрясающе!
Мобильная версия