#include<stdio.h>
int ws(int m)
{
int n = 0;
int sum = 0;
for (n = 1; n < m; n++)
{
if (m % n == 0)
{
sum += n;
}
}
if (sum == m)
{
return 1;
}
else
{
return 0;
}
}
int main()
{
int m = 0;
for (m = 1; m <= 1000; m++)
{
if (ws(m) == 1)
{
printf("%d ", m);
}
}
return 0;
}
输出1000以内的所有完数。
一个数如果恰好等于它的因子之和,这个数就称为"完数"。
完数即完全数,又称完美数或完备数,是一些特殊的自然数,它所有的真因子(即除了自身以外的约数)的和(即因子函数)恰好等于它本身。如果一个数恰好等于它的因子之和,则称该数为"完全数"。
例如6=1+2+3。
它有约数1、2、3、6,除去它本身6外,其余3个数相加,1+2+3=6。