哈哈密瓜 2022-02-26 17:37 采纳率: 100%
浏览 304
已结题

运用C语言求阶乘和数

【问题描述】
一个正整数如果等于组成它的各位数字的阶乘之和,则该正整数称为阶乘和数。例如正整数145,1!+4!+5!等于145,因此145就是一个阶乘和数。输入一个正整数,计算它的各位数字的阶乘之和,并判断它是否是一个阶乘和数。注意:输入的正整数,以及组成它的各位数字的阶乘之和都不会超过int类型的表示范围,并且输入的正整数的最高位不为0。
【输入形式】
从控制台输入一个正整数。
【输出形式】
先输出输入的正整数和一个逗号“,”,并从个位开始输出组成该正整数的各位数字的阶乘相加形式,然后输出等号“=”和各位数字阶乘之和,最后在下一行输出字符串“Yes”表示该正整数是阶乘和数,否则输出字符串“No”表示该正整数不是阶乘和数。
【输入样例1】
145
【输出样例1】
145,5!+4!+1!=145
Yes
【输入样例2】
1400
【输出样例2】
1400,0!+0!+4!+1!=27
No
【输入样例3】
4
【输出样例3】
4,4!=24
No
【样例说明】
样例1中输入的正整数为145,组成它的各位数字的阶乘之和为145,所以145为阶乘和数。样例2中输入的正整数为1400,组成它的各位数字的阶乘之和为27,所以1400不是阶乘和数。样例3中输入的正整数为4,组成它的只有一位数字,其阶乘为24,也不是阶乘和数。
【评分标准】
该题要求判断输入的正整数是否为阶乘和数,提交程序文件名为fact.c。

img

不懂为啥要用40585,32676,8000000这么具体的数字?还有其他解法吗

  • 写回答

3条回答 默认 最新

  • 关注
    
    #include <stdio.h>
    int jc(int n)
    {
        int i,s=1;
        for(i=1;i<=n;i++)
            s*=i;
        return s;
    }
    int main()
    {
        int n,t;
        int s = 0;
        int a[20],len = 0,i;
        scanf("%d",&n);
        t = n;
        
        while(t)
        {
            a[len++] = t%10;
            t/=10;
        }
         printf("%d,",n);
        for(i=0;i<len;i++)
        {
            s += jc(a[i]);
            if(i<len-1)
               printf("%d!+",a[i]);
            else
                printf("%d!=",a[i]);
        }
        printf("%d\n",s);
        if(s==n)
            printf("Yes");
        else
            printf("No");
        return 0;
    }
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月6日
  • 已采纳回答 2月26日
  • 创建了问题 2月26日

悬赏问题

  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码