本题要求实现一个计算整数因子和的简单函数,并利用其实现另一个函数,输出两正整数m和n(0<m≤n≤10000)之间的所有完数。所谓完数就是该数恰好等于除自身外的因子之和。例如:6=1+2+3,其中1、2、3为6的因子。
#include <stdio.h#include <stdio.h>
int factorsum( int number );
void PrintPN( int m, int n );
int main()
{
int m, n;
scanf("%d %d", &m, &n);
if ( factorsum(m) == m ) printf("%d is a perfect number\n", m);
if ( factorsum(n) == n ) printf("%d is a perfect number\n", n);
PrintPN(m, n);
return 0;
}
/* 你的代码将被嵌在这里 */>
```c
int factorsum( int number )
{
int sum=1;
for(int i=2;i<number;i++)
{
if(number%i==0)
{
sum+=i;
}
}
return sum;
}
void PrintPN( int m, int n )
{
int cnt=0,num,j=2;
int max=0;
for( num = n; num >= m ; num--)
{
if( factorsum (num) == num && num > max)
{
max = num;
}
}
for(int i=m;i<=n;i++)
{
if(factorsum(i)==i)
{
printf("%d = 1",i);
for(j=2;j<i;j++){
if(i%j==0)
printf(" + %d",j);
}
if(j < max)
{
printf("\n");
cnt++;
}
}
}
if(cnt==0 && max == 0)
{
printf("No perfect number");
}
}
我自己写的答案哪里出了问题呢?PTA拿不了满分
```