如果一个整数等于它的因子之和,则称该数为完数。

img


例如,6的因子为1.2.3,因为6=1+2+3.因此6就是完数。编程找出1000以内的所有完数。

img


语句代码:

import sys
import os
def demo():
    result = []
    for i in range(1,1000):
        sum = 0
        for j in range(1, i):
            if i % j == 0:
                sum += j
        if sum == i:
            result.append(str(i))
    return ",".join(result)
print("1000以内的完全数有:{}".format(demo()))

不会python c语言以前写的 仅供参考


#include<stdio.h>
int main()
{
    int i,j,sum,k;
    int a[1000];
    a[0]=1;
    for(i=2;i<=1000;i++)//1.顶层算法 
    {    
        sum=1;
        k=1;
        for(j=2;j<i;j++)
        {
            if(i%j==0)//2.判断i是否是完数 
            {
                a[k]=j;//3.细化i是否是完数 
                k++;
                sum+=j;
            }
        }
        if(sum==i)
            {    
                printf("%d It's factors are!",i);//4.考虑输出格式 
                j=0;
                while(j<k)
                {
                    printf("%d,",a[j]);//4.考虑输出格式 
                
                    j++;
                }
            putchar('\n');
            }    
    }
    return 0;
}