在完成寻找“完美数”的练习中,写了两个函数,第一个是找到M的因数,并计算因数的和,这个函数通过测试一般的整数,结果正确,比如,求6的因数和,得到6。 第二个是寻找N以下的”完美数“,用枚举的方法,把每个数都求因数和,如果和等于N本身,那么就是完美数。
但是,执行第二个函数出错,找不到哪里出错了。没学到位,不能理解,请大神帮忙。
def sum_factor(M):
'''计算N的因数的和'''
fact =[]
n1 = int(M/2)+1
for i in range(1, n1):
if (M % i) == 0:
fact.append(i)
else: continue
sumfcator = sum(fact)
return sumfcator
a = sum_factor(6)
print(a)
def perfect_number(N):
'''计算N以下的完美数'''
perf_number = []
for i in range(3,N):
if int(sum_factor(N)) == N:
perf_number.append(N)
else: return
return perf_number
b = perfect_number(6)
print(b)
错误情况,如果指定找100一下的完美数,显示找不到。
如果指定找6以下的完美数,显示找到[6,6,6],3个6。
这里发现,在4,5,6的循环中,每次都append了6,就是循环里面出错了。
请大神帮我看看,指点一下。谢谢
def sum_factor(M):
'''计算N的因数的和'''
fact =[]
n1 = int(M/2)+1
for i in range(1, n1):
if (M % i) == 0:
fact.append(i)
else: continue
sumfcator = sum(fact)
return sumfcator
a = sum_factor(6)
print(a)
def perfect_number(N):
'''计算N以下的完美数'''
perf_number = []
for i in range(3,N):
if int(sum_factor(i)) == i:
perf_number.append(i)
return perf_number
b = perfect_number(100)
print(b)
def sum_factor(M):
'''计算N的因数的和'''
fact =[]
n1 = int(M/2)+1
for i in range(1, n1):
if (M % i) == 0:
fact.append(i)
else: continue
sumfcator = sum(fact)
return sumfcator
def perfect_number(N):
'''计算N以下的完美数'''
perf_number = []
for i in range(3,N):
print(int(sum_factor(i)))
if int(sum_factor(N)) == N:
perf_number.append(i)
else: return
return perf_number
b = perfect_number(6)
print(b)
sum_factor(N)和perf_number.append(N),每次循环,n都是6,所以666
哦 判断条件写错了 只算了N 循环无意义
def perfect_number(N):
'''计算N以下的完美数'''
perf_number = []
for i in range(3,N):
if int(sum_factor(i)) == i:
perf_number.append(i)
else:
continue
return perf_number
您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632
非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!
速戳参与调研>>>https://t.csdnimg.cn/Kf0y