扶我起来我还能敲几行 2021-03-29 00:19 采纳率: 100%
浏览 45
已采纳

一个编程题目,想了一晚上不知道错在哪里,求大佬指点!!!

题目:

一个正整数如果等于组成它的各位数字的阶乘之和,该整数称为阶乘和数。 
例如,145=1!+4!+5!,则145是一个三位阶乘和数。 
请输出所有阶乘数(不会超过十万)

 

小弟的代码:

#include <stdio.h>

int jc(int n){
    if(n == 1){
        return 1;
    }
    return jc(n - 1) * n;
}

int main(){
    int x, sum = 0, a;
    for(int j = 1; j <= 40485; j++){
        a = j;
        while(j != 0){
            x = j % 10;
            j /= 10;
            sum += jc(x);
        }
        j = a;
        if(sum == a){
            printf("%d ", j);
        }
    }
    return 0;

  • 写回答

2条回答 默认 最新

  • 小白小白你好菜 2021-03-29 07:56
    关注

    循环太多,系统卡死

    #include <stdio.h>

    int b[10] = {0, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880};

    int main(){
        int x, sum = 0, a;
        for(int j = 1; j <= 100000; j++){
            sum = 0; 
            a = j;
            while(j != 0){
                x = j % 10;
                j /= 10;
                sum += b[x];
            }
            j = a;
            if(sum == a){
                printf("%d ", j);
            }
        }
        return 0;

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

报告相同问题?

悬赏问题

  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd