題目描述
一個數如果恰好等於它的因子之和,這個數就稱為"完數"。 例如,6的因子為1、2、3,而6=1+2+3,因此6是"完數"。 編程序找出N之內的所有完數,並按下面格式輸出其因子:
輸入
N
輸出
? its factors are ? ? ?
樣例輸入
1000
樣例輸出
6 its factors are 1 2 3 28 its factors are 1 2 4 7 14 496 its factors are 1 2 4 8 16 31 62 124 248
代碼:
#include<stdio.h>
int main()
{
int n,i,z;
scanf("%d",&n);
for(z=2;z<n;z++)
{
int j,b,k,a[100],sum;
b=z;k=0;sum=0;
for(j=1;j<z;j++)
{
if(z%j==0){
a[k]=j;k++;
}
}
for(i=0;i<k;i++)
sum=sum+a[i];
if(sum==b){
printf("%d its factors are ",b);
for(i=0;i<k;i++)
{
if(i+1==k)
printf("%d \n",a[i]);
else
printf("%d ",a[i]);
}
}
}
return 0;
}
