一个数如果恰好等于不包含它本身所有因子之和,这个数就称为"完数"。 例如,6的因子为1、2、3,而6=1+2+3,因此6是"完数"。 编程序找出N之内的所有完数。
代码:
#include<stdio.h>
int main() {
int n,i,j,t;
scanf("%d",&n);
for(i=1; i<=n; i++) {
int m=0;
int sum=0;
int a[1000];
for(j=1; j<i; j++) {
if(i%j==0) {
sum+=j;
a[m++]=j;
}
}
if(sum==i) {
printf("%d its factors are",i);
for(t=0;t<m;t++){
printf(" %d",a[t]);
}
printf("\n");
}
}
return 0;
}
注意:因数和和数组要在循环内初始化