《C语言及程序设计》实践参考——n=a!+b!+c!

返回:贺老师课程教学链接  项目要求


【项目2 - n=a!+b!+c!】
求满足条件n=a!+b!+c!的所有三位数n并输出,其中a,b,c分别为n的百、十、个位数。
[参考解答]

解法1:n为3位数,n由100循环到999,每次循环,分离出百、十、个位数,以此判断

#include <stdio.h>
int main()
{
    int n,a,b,c,sum;
	int i,f;
    n=100;
    while(n<1000)
    {
        c=n%10;  //个位数,
        b=(n/10)%10;  //十位数
        a=n/100;  //百位数
        sum=0;  //注意:每次循环都要初始化
		for(f=1,i=1;i<=a;++i)  f=f*i; //求 a!
		sum += f;
		for(f=1,i=1;i<=b;++i)  f=f*i; //求 b!
		sum += f;
		for(f=1,i=1;i<=c;++i)  f=f*i; //求 c!
		sum += f; //此时sum的值为a!+b!+c!
        if(sum==n)  //若条件成立,则 n 就是要找的数。
            printf("%d ", n);
        ++n;  //考察下一个n
    }
    printf("\n");
    return 0;
}

解法2:用a、b、c分别代表百、十、个位数,以此构造出n=100*a+b*10+c,按a、b、c组织循环

#include <stdio.h>
int main()
{
    int a,b,c; //分别代表百、十、个位数
    int n, sum, f, i;
    for(a=1; a<10; a++)
    {
        for(b=0; b<10; b++)
            for(c=0; c<10; c++)
            {
                n=a*100+b*10+c;
                sum=0;  //注意:每次循环都要初始化
                for(f=1,i=1; i<=a; ++i)  f=f*i; //求 a!
                sum += f;
                for(f=1,i=1; i<=b; ++i)  f=f*i; //求 b!
                sum += f;
                for(f=1,i=1; i<=c; ++i)  f=f*i; //求 c!
                sum += f; //此时sum的值为a!+b!+c!
                if(sum==n)  //若条件成立,则 n 就是要找的数。
                    printf("%d ", n);
            }
    }
    printf("\n");
    return 0;
}

解法3:按解法2的思路做,减少了求阶乘的次数

#include <stdio.h>
int main()
{
    int a,b,c; //分别代表百、十、个位数
    int fa, fb, fc; //分别代表a、b、c的阶乘
    int n, sum;
    for(fa=1, a=1; a<10; a++)
    {
        fa*=a;
        for(fb=1, b=0; b<10; b++)
        {
            if(b>0) fb*=b;  //b为0时,fb就为1(0的阶乘为1),再乘0倒危险了
            for(fc=1, c=0; c<10; c++)
            {
                if(c>0) fc*=c;
                n=a*100+b*10+c;
                sum=fa+fb+fc;
                if(sum==n)  //若条件成立,则 n 就是要找的数。
                    printf("%d ", n);
            }
        }
    }
    printf("\n");
    return 0;
}

解法n:在这个程序中,求阶乘是个耗时的事,还可以想出更多优化的方案,请读者自行补充



  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迂者-贺利坚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值