我无法获得以下内容的正确输出:
完美数字是一个数字,其正确除数的总和恰好等于数字。例如,28的适当除数之和为1 + 2 + 4 + 7 + 14 = 28,这意味着28是一个完美数。
如果n的适当除数之和小于n,则n被称为不足,如果该和超过n则称为n。
由于12是最小的有限数,1 + 2 + 3 + 4 + 6 = 16,可以写成两个有限数之和的最小数是24.通过数学分析,可以看出所有大于28123的整数可以写成两个数字的总和。然而,即使知道不能表示为两个丰富数字之和的最大数量小于该限制,也不能通过分析进一步降低该上限。
找出所有正整数的总和,这些正整数不能写为两个数字的总和。
def check(n):
s=0
for i in xrange(1,n/2+1):
if n%i==0:
s+=i
return s>n
l=100
sieve=[True]*l
for i in xrange(12):
sieve[i]=False
abundant=[]
for i in xrange(12,l):
if check(i):
abundant.append(i)
for i in xrange(len(abundant)-1):
for j in xrange(i+1,len(abundant)):
if abundant[i]+abundant[j]<l:
if sieve[abundant[i]+abundant[j]]==True:
sieve[abundant[i]+abundant[j]]=False
print abundant[i]+abundant[j]
print sum([i for i in xrange(len(sieve)) if sieve[i]])
答案 0 :(得分:1)
根据this,正确的解决方案为4179871
。
以下是修改代码的方法:
def check(n):
s=0
for i in xrange(1,n/2+1):
if n%i==0:
s+=i
return s>n
l=28123 # upper bound of a number that is not the sum of 2 abundant numbers
sieve=[False]*l # sieve[i] == True means i IS the sum of 2 abundant numbers
abundant=[]
for i in xrange(12,l):
if check(i):
abundant.append(i)
for i in xrange(len(abundant)): # ranges here are such that you don't forget something like 2*abundant[-1]
for j in xrange(i,len(abundant)):
if abundant[i]+abundant[j]<l:
sieve[abundant[i]+abundant[j]]=True
print sum([i for i in xrange(len(sieve)) if not(sieve[i])])