判断一个数是否为完数

带有分析... 带有分析 展开
 我来答
长濑绵秋
2019-01-20 · TA获得超过8165个赞
知道大有可为答主
回答量:1万
采纳率:71%
帮助的人:555万
展开全部


一、数学知识:

完数即完全数。

完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。如果一个数恰好等于它的因子之和,则称该数为“完全数”。

二、算法分析:

根据数学定义,要判断是否为完数,则需要取出所有真因子相加,然后判断是否相等即可。

三、参考代码:

#include <stdio.h>
int isPerfectNum(int n)//判断n是否为完数,如果是,则返回1,否则返回0.
{
    int i,s=0;
    for(i = 1; i < n; i ++)//遍历小于n的整数。
        if(n%i==0)//可以整除,为真因子。
            s+=i;//累加每个真因子到s上。 
    if(s==n)return 1; //符合完数条件,返回1。
    else return 0;//不是完数,返回0。
}
int main()
{
    int n;
    scanf("%d",&n);//输入n值。
    if(isPerfectNum(n))//判断是否为完数,并输出结果。
        printf("%d 是完数\n",n);
    else
        printf("%d 不是完数\n", n);
    return 0;
}



推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式