百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

2023年12月22日:十万以内阶乘和数的秘密,只有5个数字知道!

cac55 2025-03-25 11:19 29 浏览 0 评论

学习工控知识,就来工控小新

冬至 2023/12/ 22


往期推荐

2023年12月21日,每天花费一分钟练习C语言:看看你能否用递归和非递归的方式实现1+2+3+…+n的运算

你能在10秒内回答这个C语言问题吗?从键盘中输入任意一个大写字母,输出它在字母表中的位置和其后面的第四个字母

每日一练

/ Daily Exercises

题目:

一个正整数如果等于组成它的各位数字的阶乘之和,该整数成为阶乘和数。请输出所有阶乘树(不超过10万)


题目分析

阶乘和数是指一个正整数如果等于组成它的各位数字的阶乘之和,例如145是一个阶乘和数,因为

145=1!+4!+5!。

要解决这个题目,我们需要分析以下几个方面:

输入和输出:题目没有给出输入,只要求输出所有不超过10万的阶乘和数。我们可以用一个循环来遍历所有可能的正整数,然后判断它是否是一个阶乘和数,如果是,就输出它。

边界条件:题目给出了一个上限,即10万,我们可以假设这个上限是合理的,不会有更大的阶乘和数存在。另外,我们需要考虑一些特殊的情况,比如0或1,它们是否是阶乘和数?根据定义,0和1都是阶乘和数,因为0=0!,1=1!,所以我们应该把它们包含在输出中。

算法和数据结构:题目的本质是求解一个数学问题,即判断一个数是否是阶乘和数。我们可以用一个函数来实现这个判断,函数的输入是一个正整数,输出是一个布尔值,表示它是否是阶乘和数。


为了判断一个数是否是阶乘和数,我们需要做以下几个步骤:

  • 分解数字:我们需要把一个数分解成它的各位数字,然后把它们存储在一个数组中,方便后续的计算。我们可以用一个循环来实现这个分解,每次用取余运算得到最低位的数字,然后用除法运算去掉最低位,直到数变为0为止。
  • 计算阶乘:我们需要计算每个数字的阶乘,然后把它们相加,得到一个和。我们可以用一个数组来存储0到9的阶乘,这样可以避免重复计算,提高效率。我们可以用一个循环来初始化这个数组,然后用一个循环来遍历分解后的数字,根据数组的索引得到对应的阶乘,然后累加到和中。
  • 比较和:我们需要比较计算出的和和原来的数是否相等,如果相等,就说明这个数是一个阶乘和数,返回真,否则返回假。



程序展示

#include 
#include 
#include 


// 定义一个常量,表示上限
#define MAX 100000


// 定义一个函数,输入一个正整数,输出它是否是一个阶乘和数
bool isFactorialSum(int n) {
    // 初始化一个数组,用来存储0到9的阶乘
    int factorials[10] = {1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880};
    // 初始化一个变量,用来存储阶乘之和
    int sum = 0;
    // 初始化一个变量,用来存储原始的数
    int original = n;
    // 用一个循环来分解数字,直到数变为0为止
    while (n > 0) {
        // 用取余运算得到最低位的数字
        int digit = n % 10;
        // 用除法运算去掉最低位
        n = n / 10;
        // 根据数组的索引得到对应的阶乘,然后累加到和中
        sum = sum + factorials[digit];
    }
    // 比较和和原始的数是否相等,如果相等,返回真,否则返回假
    return sum == original;
}


// 定义一个主函数,用来测试
int main() {
    // 用一个循环来遍历所有可能的正整数,从0开始,直到上限为止
    for (int i = 0; i < MAX; i++) {
        // 调用函数,判断当前数是否是一个阶乘和数
        if (isFactorialSum(i)) {
            // 如果是,就输出它
            printf("%d\n", i);
        }
    }
    // 返回0,表示程序正常结束
    return 0;
}


程序测试

为了验证代码的正确性,我们可以在VC6.0的环境下运行这个程序,观察输出是否符合预期。根据数学上的分析,不超过10万的阶乘和数只有5个,分别是0,1,2,145和40585。

下面是运行的截图:


源代码获取

#软件下载通道#



我用夸克网盘分享了「20231222」,点击链接即可保存。打开「夸克APP」,无需下载在线播放视频,畅享原画5倍速,支持电视投屏。

链接:
https://pan.quark.cn/s/d9bb3370bfd1

(链接和提取码建议复制粘贴,手动输入容易出现错误)

#支持一下#

分享整理,测试发布不易 如果您方便的话可以帮忙点一下↓↓

谢谢大家!



下期题目

给定一个非负索引rowindex,返回杨辉三角的第rowindex行。


点赞加关注,学习不迷路

微信公众号|工控小新

学习工控知识就来工控小新,为你提供工控笔记知识:EPLAN电气绘图 | TIA博图基础 | CAD | C语言教学 | 单片机基础 | 三菱PLC ... 每日持续更新中


#头条创作挑战赛#


相关推荐

PDF转Excel后,转出的表格全是乱码是怎么回事?

日常工作中经常会用到将各种办公文档不同格式进行互转,比如将PDF转成Excel,这种转换非常简单,工具也很多,但是有时PDF文档是正常的,转出来的表格却全是乱码是怎么回事呢?在PDF转Excel时,你...

Python CSV 模块通关秘籍:数据表格处理不求人

对话实录小白:(苦恼)我导出的CSV用Excel打开全是乱码!专家:(递上秘籍)(掏出魔法书)**编码问题!用utf-8-sigma保存!CSV格式初体验CSV后缀的文件是标准文件格式,可以通过文本编...

ArcMap碎碎念(常见使用问题集锦)(arcgis细碎小班)

这几日,由于工作原因,频繁使用ArcMap,期间也碰到了些许问题,因而攒了这篇文章,以作记录。1.数据转换:mxd转mpk格式后缀为mxd的文件类型在ArcGIS的使用过程中较为常见,也即为常见的地图...

Excel常用技能分享与探讨(4-经常遇到的问题点汇总②)

一、文件异常问题Excel文件损坏无法打开现象:提示“文件已损坏”“无法读取内容”或直接闪退。解决:使用【文件】→【打开】→选择文件→点击右下角【打开】下拉箭头→选择【打开并修复】。若失败,尝...

解决Excel“#”乱码的方法来了(excel表格嵌入图片别人打开是乱码怎么解决)

小编本人是个表格控,没有excel可能分分钟就会焦虑,刚用excel大概半年多的时间,随着数据传递的频繁和增多,发现了一个奇怪的问题。做好的表格保存后再打开会变成“###”还有时,会出现这样的日期这时...

如何修复损坏的 Excel 文件?3 个方法救回重要数据

有没有遇到这种情况:打开Excel提示“文件已损坏,无法打开”明明很重要的数据,却打不开了…别急!今天分享3个实用方法,帮你修复Excel文件,拯救重要数据!方法一:用Excel自带...

为什么你的 GIS 数据总是出现乱码?

你肯定遇到过这种情况:把GIS文件拖进BigemapPro,但为啥文字就变成了乱码?例如这样:遇到这种情况呢,你也别急,我来教你怎么处理。一、三调数据文件乱码我们通常拿到的三调数据文件是GDB格式的,...

Excel表格数字乱码怎么办?推荐四种简单方法

我们经常利用Excel表格录入数据,在录入数据的时候我们经常会遇到这种情况:因为录入的数字的数位较多导致数字乱码。这种情况真的很影响我们的工作进程。那么Excel表格数字乱码该怎么办呢?推荐大家使用这...

使用Excel时经常遇到的问题,别担心,轻松告诉你解决方案

Excel打开CSV文件为乱码的解决方法!Excel中外部数据链接无法删除怎么办?Excel打开CSV文件为乱码的解决方法!从网页上导出数据文件存储为CSV格式的文件,使用记事本打开文字显示没有问题,...

解决数据恢复软件——恢复的excel文件乱码问题

恢复的excel文件出现乱码通常与原始文件损坏有关,为了解决数据恢复后excel乱码问题,建议使用数据恢复软件的深度恢复扫描,再次扫描需要恢复的excel文件所在磁盘,该扫描方式能对硬件设备进行碎片文...

Excel表格中怎么删除乱码?一秒搞定

随着我们越来越多的使用Excel,我们会发现很多情况下Excel会返回一串乱码似的字符。这些其实并不是乱码。Excel执行公式运算时都会自动对单元格中输入的公式进行检查,当公式如果不能正确地计算时返回...

EXCEL打开CSV等数据文件是乱码怎么办?

使用Data.olllo数据助手解决EXCEL打开CSV、TXT数据乱码的问题计算机存储的文件是有不同的编码方式,而有时候EXCEL打开CSV或TXT文件的时候,发现是乱码,这时候应该怎么办呢?工具:...

Excel表格出现乱码,怎么办?只需要7步,就能完美解决问题

当打开表格时出现乱码,首先需要检查文件的编码格式,确认文件编码格式是否与本地编码格式一致。如果编码格式不一致,可以在打开表格时选择正确的编码格式。如果不确定编码格式,可以试着把文件保存为ANSI或者...

我的Excel打开后是一堆乱码,如何解决?

Excel文件内容变成乱码,可能由于文件编码、文件格式或Excel程序设置的问题导致。以下是一些有效的解决方案,可以帮助你解决Excel乱码问题1.确认文件编码是否正确如果文件是从外部导入的(例如C...

Excel文件打开乱码问题解决方法详解

在日常办公或数据处理中,Excel文件是极为常用的工具。然而,有时当我们尝试打开一个Excel文件时,可能会遇到内容显示为乱码的情况,这不仅影响工作效率,还可能导致重要数据的丢失或损坏。本文将详细介绍...

取消回复欢迎 发表评论: