如果一个正整数的所有因子之和等于该正整数,则称为该正整数为完全数,编写程序输入n,输出不超过n的全部正完全数。
时间: 2024-12-02 13:18:25 浏览: 23
下面是一个简单的C语言程序,用于找到并输出所有小于或等于指定正整数n的完全数:
```c
#include <stdio.h>
#include <stdbool.h> // 添加这个头文件以便使用bool类型
bool isPerfectNumber(int num) {
int sum = 1; // 初始化因子和为1,因为1总是任何数的因子
for (int i = 2; i * i <= num; i++) { // 只需检查到sqrt(num),避免重复计算
if (num % i == 0) {
// 如果i是因子,加到sum上,并检查另一个因子
sum += i;
if (i != num / i) {
// 如果不是自身,再加第二个因子
sum += num / i;
}
}
}
// 判断sum是否等于num,如果是,则返回true,表示num是完全数
return sum == num;
}
int main() {
int n;
printf("请输入一个正整数n: ");
scanf("%d", &n);
printf("小于或等于%d的正完全数有:\n", n);
for (int i = 6; i <= n; i++) { // 所有大于6的正整数都是偶数,可以从6开始找
if (isPerfectNumber(i)) {
printf("%d\n", i);
}
}
return 0;
}
```
这个程序首先定义了一个辅助函数`isPerfectNumber`,用于判断一个数是否为完全数。在主函数中,用户输入一个正整数n,然后遍历从6开始的所有偶数(因为所有非平凡完全数都是6的倍数),对每个数调用`isPerfectNumber`函数,如果是完全数就输出。
阅读全文