int factorsum( int number )
{
int sum = 0;
int i = 0;
for(i = 1;i < number;i++)
{
if(number % i == 0)
sum += i;
}
return sum;
}
void PrintPN( int m, int n )
{
int arr[100];
int i = 0;
int j = 0;
int k = 0;
int h = 0;
int count = 0;
for(i = m;i <= n;i++)
{
if(factorsum(i) == i)
{
count++;
for(j = 2;j < i;j++)
{
if(i % j == 0)
{
arr[k++] = j;
}
}
printf("%d = 1",i);
for(h = 0;h < k;h++)
printf(" + %d",arr[h]);
k = 0;
printf("\n");
}
}
if(count == 0)
printf("No perfect number");
}
主要在于创建一个数组来存放完数的因子;同时有一点要注意,就是每存放完一个完数的因子并输出之后,要重置数组的下标,在新一次的循环中,储存新的完数因子;最后还要按照格式输出。