思路
求公约数后求和,比较
放到函数中,内存用完就释放,防止内存溢出
Answer
#include <stdio.h>
int func(int n)
{
int i;
int sum=0;
for(i=1;i<n;i++)
{
if(n%i==0)
{
sum+=i;
}
}
if(sum==n)
return 1;
else
return 0;
}
int main()
{
int n;
int i,j;
while(scanf("%d",&n)!=EOF)
{
int result=0;
for(i=1;i<=n;i++)
{
if(func(i))
result++;
}
printf("%d\n",result);
}
return 0;
}