/*一个数恰好等于它的因子之和.6=1+2+3*/
#include
#define N 2000 /*搜索范围在1000以内*/
int wanshu(int x) /*判断x是否完数*/
{
int i,sum=0;
// int factor[N]={0};
for(i=1;i<=x;i++) /*对所有x的因子求和*/
{
if(x%i==0) sum=sum+i;
continue;
}
if(sum==x*2) return(1); /*如果求和结果等于2x则x是完数*/
else return(0); /*否则不是完数*/
} /*完数判断函数结束*/
int print_factor(int x) /*打印结果*/
{
int i,j,res[N]={0}; /*i,j为循环变量.res数组记录每个因子.*/
for(i=1;i
if(x%i==0) res[i]=i;
continue;
}
printf("%d 它的因子有: ",x); /*打印提示*/
for(j=0;j
if(res[j]!=0)
{
printf("%d",res[j]);
printf("\,");
}
}
printf("\n");
return(0);
} /*打印函数结束*/
int main() /*主函数*/
{
int i; /*循环变量*/
for(i=1;i<=N;i++) /*循环找出小于N的所有完数并输出其因子.*/
{
if(wanshu(i)) print_factor(i);
continue;
}
return 0;
} /*主函数结束*/
太长了,比书上写的长了几倍。。。