用c语言怎样编写n个数以内的完全数的程序

如题所述

完全数是指所有真因子之和等于该数本身的正整数。可以使用以下C语言代码来找出小于等于n(n为正整数)的完全数:

```c
#include <stdio.h>

int main() {
int n, i, j, sum;

printf("请输入一个正整数n:");
scanf("%d", &n);

for (i = 1; i <= n; ++i) {
sum = 0;
for (j = 1; j <= 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的一半的因子已经在之前被计算过了。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-04-16
#include <stdio.h>
#include <math.h>

int main()
{
int a,b,c,sum=0;
scanf("%d",&a);
for(b=1;b<=a;b++)
{
sum = 0;
for(c=1;c<b;c++)
{
if(b%c==0)
sum=sum+c;
else
continue;
}
if(sum==b)
printf("%d\n",b);
}
return 0;
}追问

我用linux怎嘛运行不出结果呀??

追答

windows vc6.0运行正常
linux下直接在终端编译运行的嘛?

追问

en 在终端运行不出来怎嘛办呀

本回答被提问者采纳
第2个回答  2012-04-16
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
int i,j;
int sum=0;
for(i=1;i<=n;++i)
{
for(j=2;j<=i/2;++j)
{
if(i%j==0&&i/j!=i)
sum+=i/j;
}
if(sum==i)
printf("%d\n",i);
sum=1;
}
return 0;
}
相似回答