1150:求正整数2和n之间的完全数 时间限制: 1000 ms 内存限制: 65536 KB 提交数: 52461 通过数: 32365 【题目描述】 求正整数22和nn之间的完全数(一行一个数)。 完全数:因子之和等于它本身的自然数,如6=1+2+36=1+2+3 【输入】 输入n(n≤5000)n(n≤5000)。 【输出】 一行一个数,按由小到大的顺序。 【输入样例】 7 【输出样例】 6 【代码】 #include
int isperfect_number(int n)
{int i,k,s=1;k=sqrt(n);for(i=2;i<=k;i++){if(n%i==0)s+=i+n/i;}if(s==n)return 1;elsereturn 0;
}
int main()
{int i,n;scanf("%d",&n);for(i=2;i<=n;i++){if(isperfect_number(i))printf("%d\n",i);}return 0;
} |