判断任意正整数n是否为完全数 C语言代码
时间: 2024-05-01 21:18:47 浏览: 22
这是一个判断任意正整数n是否为完全数的C语言代码:
```
#include <stdio.h>
int main() {
int n, sum = 0;
printf("请输入一个正整数n:");
scanf("%d", &n);
for (int i = 1; i < n; i++) {
if (n % i == 0) {
sum += i;
}
}
if (sum == n) {
printf("%d是完全数\n", n);
} else {
printf("%d不是完全数\n", n);
}
return 0;
}
```
该代码首先让用户输入一个正整数n,然后用一个for循环计算n的因数和,最后判断因数和是否等于n,如果是,则n为完全数,否则不是。
相关问题
c语言代码求正整数2和n之间的所有完全数
完全数是指一个数恰好等于它的因子(不包括它本身)之和,例如6就是一个完全数,因为6的因子是1、2、3,而1+2+3=6。下面是求正整数2和n之间的所有完全数的C语言代码:
```c
#include <stdio.h>
int main()
{
int n, i, j, sum;
printf("请输入一个正整数n:");
scanf("%d", &n);
printf("2到%d之间的完全数有:\n", n);
for(i=2; i<=n; i++)
{
sum = 0;
for(j=1; j<i; j++)
{
if(i%j==0)
{
sum += j;
}
}
if(sum == i)
{
printf("%d ", i);
}
}
printf("\n");
return 0;
}
```
代码的思路是先输入一个正整数n,然后使用for循环遍历2到n之间的每一个数字。对于每一个数字i,再使用另一个for循环遍历1到i-1之间的每一个数字j,如果j是i的因子,就将j加入到sum变量中。最后判断sum是否等于i,如果是,则i是一个完全数,输出i即可。
求正整数2和n之间的所有完全数C语言
完全数是指一个正整数的所有因子(除了自身)之和等于它本身的数。以下是求正整数2和n之间的所有完全数的C语言代码:
```c
#include <stdio.h>
int main() {
int n, i, j, sum;
printf("请输入一个正整数n:");
scanf("%d", &n);
printf("2到%d之间的完全数有:\n", n);
for (i = 2; i <= n; i++) {
sum = 1;
for (j = 2; j < i; j++) {
if (i % j == 0) {
sum += j;
}
}
if (sum == i) {
printf("%d ", i);
}
}
return 0;
}
```
该代码中使用了两个for循环嵌套,外层循环控制数字的范围,内层循环计算所有因子之和。判断是否为完全数的条件是所有因子之和等于该数字本身。输出所有完全数时,使用printf函数将符合条件的数字依次输出。