《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

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


【项目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:在这个程序中,求阶乘是个耗时的事,还可以想出更多优化的方案,请读者自行补充



相关实践学习
基于函数计算一键部署掌上游戏机
本场景介绍如何使用阿里云计算服务命令快速搭建一个掌上游戏机。
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
目录
相关文章
|
1月前
|
存储 C语言
C语言顺序结构:基础与实践
C语言,作为一种广泛使用的编程语言,其程序结构可以分为三种基本类型:顺序结构、选择结构和循环结构。在这篇文章中,我们将重点讨论顺序结构的概念、特点以及如何在C语言中实现顺序结构的程序设计。
39 1
|
1月前
|
C语言
C语言模块化程序设计
C语言模块化程序设计
21 0
|
1月前
|
C语言
【C语言】循环结构程序设计(第二部分 -- 习题讲解)
【C语言】循环结构程序设计(第二部分 -- 习题讲解)
C4.
|
1月前
|
程序员 C语言
C语言循环结构与程序设计
C语言循环结构与程序设计
C4.
23 0
|
1月前
|
存储 文件存储 C语言
《C语言程序设计》课程设计 -- 火车票票务管理系统
《C语言程序设计》课程设计 -- 火车票票务管理系统
23 1
|
1月前
|
存储 C语言
C语言顺序结构程序设计
C语言顺序结构程序设计
21 0
|
1月前
|
Unix Linux C语言
【C/C++ 跳转函数】setjmp 和 longjmp 函数的巧妙运用: C 语言错误处理实践
【C/C++ 跳转函数】setjmp 和 longjmp 函数的巧妙运用: C 语言错误处理实践
19 0
|
1月前
|
存储 C语言
C语言的顺序程序设计
C语言的顺序程序设计
11 2
|
1月前
|
存储 C语言
C语言的顺序程序设计
C语言的顺序程序设计
15 0
|
1月前
|
C语言
【C语言】用函数实现模块化程序设计
【C语言】用函数实现模块化程序设计