
完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。
它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。
如果一个数恰好等于它的真因子之和,则称该数为“完全数”。
第一个完全数是6,第二个完全数是28,第三个完全数是496,后面的完全数还有8128、33550336等等。
如果一个数恰好等于它的真因子之和,则称该数为“完全数” 。各个小于它的约数(真约数,列出某数的约数,去掉该数本身,剩下的就是它的真约数)的和等于它本身的自然数叫做完全数(Perfect number),又称完美数或完备数。
例如:
第一个完全数是6,它有约数1、2、3、6,除去它本身6外,其余3个数相加,1+2+3=6。
第二个完全数是28,它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加,1+2+4+7+14=28。
第三个完全数是496,有约数1、2、4、8、16、31、62、124、248、496,除去其本身496外,其余9个数相加,1+2+4+8+16+31+62+124+248=496。
后面的完全数还有8128、33550336等等。
本文完数
问题的描述
如下几点所示
本文C语言经典算法实例的编译环境,使用的是集成开发环境:Visual Studio 2019

Visual Studio 2019官网链接如下
Visual Studio 2019集成的开发环境的特点有
包含头文件 代码如下所示
#pragma once
// 包含头文件
#include
#include
声明变量 代码如下所示
// 声明变量
int i, j, k;
使用for循环来求1-10000的完数 代码如下所示
///
/// 使用for循环来求1-10000的完数
///
/// 无
for (i = 1; i < 10000; i++)
{
}
变量赋值 代码如下所示
// 变量赋值, 保证每次循环时sum的初值为0
int sum = 0;

判断j是否为i的因子,代码如下所示
for (j = 1; j < i; j++)
{
///
/// // 判断j是否为i的因子
///
///
if (i % j == 0)
{
sum += j;
}
}
判断因子数是否和原数相等 代码如下所示
///
/// 判断因子数的和是否和原数相等
///
///
if (sum == i)
{
printf("%d 的因数是: ", i);
for (k = 1; k < i; k++)
{
if (i % k == 0)
{
printf("%d ", k);
}
}
printf("\n");
}
按F5进行编译,调试结果如下所示。

6 的因数是: 1 2 3
28 的因数是: 1 2 4 7 14
496 的因数是: 1 2 4 8 16 31 62 124 248
8128 的因数是: 1 2 4 8 16 32 64 127 254 508 1016 2032 4064
请按任意键继续. . .
对求1-10000内的完数功能进行函数模块化 代码如下所示。
///
/// 求完数的函数声明
///
void numberPerfect();
对求1-10000内的完数功能进行函数模块化的函数定义 代码如下所示。
///
/// 求完数的函数定义
///
void numberPerfect()
{
// 声明变量
int i, j, k;
///
/// 使用for循环来求1-10000的完数
///
/// 无
for (i = 1; i < 10000; i++)
{
// 变量赋值, 保证每次循环时sum的初值为0
int sum = 0;
for (j = 1; j < i; j++)
{
///
/// // 判断j是否为i的因子
///
///
if (i % j == 0)
{
sum += j;
}
}
///
/// 判断因子数的和是否和原数相等
///
///
if (sum == i)
{
printf("%d 的因数是: ", i);
for (k = 1; k < i; k++)
{
if (i % k == 0)
{
printf("%d ", k);
}
}
printf("\n");
}
}
printf("\n");
}
主函数中调用求1-10000内的完数功能的函数numberPerfect 代码如下所示
// 调用求完数的函数
numberPerfect();
按F5进行编译,调试结果如下所示。

经典算法实例程序完整代码如下所示
#pragma once
// 包含头文件
#include
#include
///
/// 求完数的函数声明
///
void numberPerfect();
#define _CRT_SECURE_NO_WARNINGS
#include "Main.h"
///
/// 主函数
///
/// 返回0
int main()
{
system("color 3E");
// 调用求完数的函数
numberPerfect();
system("pause");
return 0;
}
///
/// 求完数的函数定义
///
void numberPerfect()
{
// 声明变量
int i, j, k;
///
/// 使用for循环来求1-10000的完数
///
/// 无
for (i = 1; i < 10000; i++)
{
// 变量赋值, 保证每次循环时sum的初值为0
int sum = 0;
for (j = 1; j < i; j++)
{
///
/// // 判断j是否为i的因子
///
///
if (i % j == 0)
{
sum += j;
}
}
///
/// 判断因子数的和是否和原数相等
///
///
if (sum == i)
{
printf("%d 的因数是: ", i);
for (k = 1; k < i; k++)
{
if (i % k == 0)
{
printf("%d ", k);
}
}
printf("\n");
}
}
printf("\n");
}
本文的C语言经典算法实例:完数,要实现的目标如下

文到这里就结束啦。
希望本文的C语言经典算法实例:完数。
能激发你对C语言以及算法学习的热爱。