1150:求正整数2和n之间的完全数
时间限制: 1000 ms 内存限制: 65536 KB
提交数: 28595 通过数: 17219
【题目描述】
求正整数2和n之间的完全数(一行一个数)。
完全数:因子之和等于它本身的自然数,如6=1+2+3
【输入】
输入n(n≤5000)。
【输出】
一行一个数,按由小到大的顺序。
【输入样例】
7
【输出样例】
6
#include<iostream>
using namespace std;
int y(int x);
int main()
{
int n,i;
cin>>n;
for(i=2; i<=n; i++)
if(y(i)==i) cout<<i<<endl;
return 0;
}
int y(int x)
{
int i,s=0;
for(i=1;i<=x-1;i++)
if(x%i==0) s+=i;
return s;
}