C语言实现输出1000以内的所有完全数

来自:网络
时间:2024-09-10
阅读:

C语言输出1000以内的所有完全数

#include <stdio.h>

int main()
{
    int i,j;
    
    printf("1000以内的所有完数:");
    
    for(i=1;i<=1000;i++)
    {
        int sum=0;
        for(j=1;j<i;j++)
        {
            if(i%j==0)
                sum = sum+j;
        }
        if(sum==i)
            printf("%d  ",i);
    }
    printf("\n");
           
    return 0;
}

输出结果:

1000以内的所有完数:6 28 496

C语言输出两数之间的所有完全数

编写程序,输入两个正整数m和n(1<=m,n<=10000),输出两数之间的所有完全数。

要求定义并调用函数perfectNumber(?)判断n是否是完全数。

完全数:所有的真因子的和恰好等于它本身的自然数。

例如:28是一个完全数,它有真因子1、2、4、7、14,相加等于28。

//完美数,一个数恰好等于其因子之和
#include<stdio.h>

void perfectnum(int m,int n);

int main() {
    int m,n;
    printf("输入两个正整数m和n(1<=m,n<=10000):");
    scanf("%d %d",&m,&n);
    perfectnum(m,n);
    return 0;
}

void perfectnum(int m,int n)
{
    int a;
    int i;
    int sum;
    for(a=m;a<n;a++)
 //求的m-n的完美数
    {
        sum=0;
        for (i=1; i<=a/2; i++)
//减少循环的次数,判断到一半时就可以判断出所有的因子
        {
            if(a%i==0)
                sum=sum+i;
        }
        if (a==sum) {
            printf("%d是完美数\n",a);
        }
    }
}


输出

输入两个正整数m和n(1<=m,n<=10000):0 1000
0是完美数
6是完美数
28是完美数
496是完美数

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

返回顶部
顶部