一个数如果恰好等于它的因子之和,这个数就称为完数。例如,6的因子为1,2,3,而6=1+2+3,因此6是完数。
找出1000以内的完数
#include <stdio.h>
int main()
{
int a, b, c ;
for (a = 2; a < 1000; a++)
{
b = 0;
for (c = 1; c < a; c++) //循环找因子
if ((a % c) == 0) //当数字被整除时即为它的因子
b= b + c; //将因子累加得完数
if (b == a)
{
printf("%d its factors are", a); //输出完数
for (c = 1; c < a; c++)
if (a % c == 0) //同样的循环进而输出因子
printf("%d ", c);
printf("\n");
}
}
return 0;
}
输出结果
6 its factors are1 2 3
28 its factors are1 2 4 7 14
496 its factors are1 2 4 8 16 31 62 124 248
D:\code\2022\Project1\Debug\Project1.exe (进程 6476)已退出,代码为 0。
按任意键关闭此窗口. . .