
```c
#include <stdio.h>
int main() {
int n, i, j, sum
printf("请输入一个正整数n:")
scanf("%d", &n)
for (i = 1i <= n++i) {
sum = 0
for (j = 1j <= i / 2++j) {
if (i % j == 0) {
sum += j
}
}
if (sum == i) {
printf("%d\n", i)
}
}
return 0
}
```
解释如下:
1. 首先,定义变量n、i、j和sum。
2. 要求用户输入n。
3. 使用两个嵌套的循环来遍历从1到n的每个数字。
4. 内部循环计算数字i的所有真因子之和。
5. 如果该总和等于数字i本身,则输出该数字,即它是一个完全数。
6. 最后返回0结束程序。
注意,此代码中包含了一个优化,即内部循环只需要遍历1到i的一半,因为大于i的一半的因子已经在之前被计算过了。
完数,即完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。其所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于本身。
根据该定义 可以得出判断完数的函数如下:
#include <stdio.h>int is_perfect_number(int n)
{
int i,s=0
for(i = 1 i <=n/2 i ++)
if(n%i == 0) s+= i//统计所有真因子的和。
if(s == n) return 1//如果与原值相等,则该数为完数。
return 0//不是完数。
}
根据该函数,只需要对需要打印的范围内所有数做遍历,并逐一调用该函数判断,如果返回1则打印即可。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)