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

该程序实现了一个寻找2到n之间完全数的功能。完全数是指所有因子(除自身外)之和等于本身的自然数,例如6。程序通过输入n(n≤5000),遍历并检查每个数是否为完全数,并按顺序输出结果。
207

被折叠的 条评论
为什么被折叠?



