题目:
找出1~9999之间的所有完美数
完美数是除自身外其他所有因子的和正好等于这个数本身的数
例如: 6 = 1 + 2 + 3, 28 = 1 + 2 + 4 + 7 + 14
为什么我的代码运行结果有问题?(在我看来)别人的代码与我的差别在范围,但是别人的就可行?
图一为我的代码,图三为别人代码
请帮忙看看我的代码问题在哪?
题目:
找出1~9999之间的所有完美数
完美数是除自身外其他所有因子的和正好等于这个数本身的数
例如: 6 = 1 + 2 + 3, 28 = 1 + 2 + 4 + 7 + 14
为什么我的代码运行结果有问题?(在我看来)别人的代码与我的差别在范围,但是别人的就可行?
图一为我的代码,图三为别人代码
请帮忙看看我的代码问题在哪?
你的代码中,if j!=i//j and j>1:这个代码块是多余的。导致重复累加了因子
在你的循环中,是从1到n-1都进行整除判断,这个循环已经实现了所有因子的累加了
而在第二段代码中,循环只是从1到n开根号+1,所以需要通过if语句来补充后面的因子
举个例子
假设n=6,那么你的循环会将1,2,3都累加
但第二段代码只是从1循环到根号6+1,也就是3,但实际循环就是对1和2进行处理。在这个累加过程中,3并没有加入。而这个if会将3加入。因为result += num//factor,这里factor = 2,num=6,所以result会加上3