C语言中找出完美数及其因子238


完美数是一个正整数,它等于其所有真因子的和。换句话说,一个完美数的真因子之和等于其自身。例如,6是一个完美数,因为它的真因子(1、2和3)之和等于自身(6)。

C语言实现

我们可以使用以下算法在C语言中查找完美数:```c
#include
int main() {
int num, sum, i;
printf("输入一个正整数:");
scanf("%d", &num);
sum = 0;
for (i = 1; i < num; i++) {
if (num % i == 0) {
// 如果i是num的因子,则累加i
sum += i;
}
}
if (sum == num) {
printf("%d是一个完美数", num);
} else {
printf("%d不是完美数", num);
}
return 0;
}
```

算法描述

该算法使用循环来检查数字从1到num-1是否是num的因子。对于每个因子,它将因子添加到总和中。如果最后总和等于num,则num是完美数。否则,num不是完美数。

输出因子的方式

如果输入的数字是完美的,则该程序不仅会打印出它是完美的,还会打印出它的所有因子。以下是修改后的程序代码:```c
...
if (sum == num) {
printf("%d是一个完美数,其因子为:", num);
for (i = 1; i < num; i++) {
if (num % i == 0) {
printf("%d ", i);
}
}
}
...
```

修改后的程序将在打印完美数之后打印出它的所有因子,使用空格分隔。

示例运行

以下是一次示例运行,输入数字6:```
输入一个正整数:6
6是一个完美数,其因子为:1 2 3
```

2024-10-28


上一篇:C 语言函数名:命名规则与最佳实践

下一篇:函数嵌套在 C 语言中的强大功能