编写程序找出1000以内的所有完数,利用数组输出?

编写程序找出1000以内的所有完数,并按下面格式输出因子:
6 its factors are 1,2,3

#include 
int main()
{
    int i,j,k,f,sum,factor[100];
    for(i=1;i<=1000;i++)
    {
        sum=0;
        for(j=1;jk=0;
            if(i%j==0)
            {
                sum+=j;
                factor[k]=j;
                k++;
            }
        }
        if(sum==i)
        {
            printf("%d\tits factors are ",i);
            for(f=0;f"%d,",factor[f]);
            }
            printf("\n");
        }
    }
    return 0;
}

在使用数组输出时为什么会出错?
以下是运行结果:

img

你用来记录数组长度的k的值,在打印的时候已经回归到0了,所以你需要把内层for循环中的k = 0;移动到该for循环之上。

#include <stdio.h>
int main()
{
    int i,j,k,f,sum,factor[100];
    for(i=1;i<=1000;i++)
    {
        sum=0;
        
        k=0;
        for(j=1;j<i;j++)
        {
            if(i%j==0)
            {
                sum+=j;
                factor[k]=j;
                k++;
            }
        }
        if(sum==i)
        {
            printf("%d\tits factors are ",i);
            for(f=0;f<k;f++)
            {
                printf("%d,",factor[f]);
            }
            printf("\n");
        }
    }
    return 0;
}

以下回答来自chatgpt, 有用的话请采纳
完数是指一个数恰好等于它的因子之和,例如6是一个完数,因为6=1+2+3。以下是C语言程序实现:

#include <stdio.h>

int main() {
    int i, j, sum;
    int perfect[1000], count = 0;

    for (i = 1; i <= 1000; i++) {
        sum = 0;
        for (j = 1; j < i; j++) {
            if (i % j == 0) {
                sum += j;
            }
        }
        if (sum == i) {
            perfect[count] = i;
            count++;
        }
    }

    printf("1000以内的完数有:\n");
    for (i = 0; i < count; i++) {
        printf("%d ", perfect[i]);
    }
    printf("\n");

    return 0;
}

程序中定义了一个数组perfect用于存储找到的完数,count用于记录完数的个数。程序通过两层循环遍历1到1000的所有数,对于每个数i,内层循环计算它的因子之和sum。如果sum等于i,说明i是一个完数,将其存入数组perfect中,并将count加1。最后输出数组perfect中存储的完数即可。