当前位置: 首页 > news >正文

【重生之学习C语言----水仙花篇】

目录

​编辑

----------------------------------------begin--------------------------------------

一、什么是水仙花数?

二、问题分析

确定数字的位数:计算输入数字的位数 n。

分离每一位数字:例如将 153 分离为 1、5、3。

计算各位的n次方和:将每一位的 n 次方相加。

判断是否相等:比较和与原数是否相等。

三、算法设计

计算位数:

分离每一位:

计算次方和:

判断逻辑:

四、代码实现

完整代码:

代码解析:

五、运行结果

六、关键问题与优化

为什么从100开始遍历?

如何处理更大的数字?

手动实现幂运算(避免依赖 math.h):

七、总结

路过的佬们点点关注哦~

你们的鼓励是我前进的动力~

----------------------------------------------end------------------------------------------


----------------------------------------begin--------------------------------------

一、什么是水仙花数?

水仙花数(Narcissistic Number),又称阿姆斯特朗数,是指一个 n 位数的正整数,其各位数字的 n 次方之和等于它本身。例如:

  • 153 是3位水仙花数:13+53+33=15313+53+33=153

  • 9474 是4位水仙花数:94+44+74+44=947494+44+74+44=9474


二、问题分析

要实现水仙花数的判断,需要解决以下问题:

  • 确定数字的位数:计算输入数字的位数 n
  • 分离每一位数字:例如将 153 分离为 153
  • 计算各位的n次方和:将每一位的 n 次方相加。
  • 判断是否相等:比较和与原数是否相等。


三、算法设计

  • 计算位数
    • 通过循环除以10统计次数,直到数字变为0。

  • 分离每一位
    • 使用取模(% 10)获取最后一位,再通过整除(/ 10)移除该位。

  • 计算次方和
    • 调用 math.h 中的 pow 函数,或手动实现幂运算。

  • 判断逻辑
    • 如果次方和等于原数,则为水仙花数。

四、代码实现

  • 完整代码:
#include <stdio.h>
#include <math.h>int isNarcissistic(int number) {int original = number;int sum = 0;int digits = 0;int temp = number;// 计算位数while (temp != 0) {temp /= 10;digits++;}// 恢复原始值temp = original;// 计算各位的次方和while (temp != 0) {int remainder = temp % 10;sum += pow(remainder, digits);temp /= 10;}// 判断是否相等return (sum == original);
}int main() {int lower = 100;   // 水仙花数至少是三位数int upper = 9999;  // 示例范围扩大到四位数printf("水仙花数(%d - %d):\n", lower, upper);for (int i = lower; i <= upper; i++) {if (isNarcissistic(i)) {printf("%d\n", i);}}return 0;
}
  • 代码解析:
  • isNarcissistic函数

    • 计算位数:通过 while 循环统计除以10的次数。

    • 分离各位数字:通过 % 10 取余和 / 10 整除操作。

    • 次方和计算:使用 pow(remainder, digits) 计算每位数字的 n 次方。

  • main函数

    • 遍历指定范围(如100-9999)内的所有数字。

    • 调用 isNarcissistic 判断是否为水仙花数并输出。

五、运行结果

水仙花数(100 - 9999):
153
370
371
407
1634
8208
9474

六、关键问题与优化

  • 为什么从100开始遍历
    • 水仙花数至少是三位数(如153),两位数无法满足条件。

  • 如何处理更大的数字
    • 调整 upper 的值即可,但需注意数据溢出问题(int 类型上限约为 231−1231−1)。

  • 手动实现幂运算(避免依赖 math.h):
int power(int base, int exponent) {int result = 1;for (int i = 0; i < exponent; i++) {result *= base;}return result;
}

七、总结

通过本博客,你学会了:

  1. 水仙花数的定义与数学原理。

  2. 分步骤算法设计:计算位数、分离数字、次方求和。

  3. C语言实现技巧:循环、条件判断、函数封装。

  4. 扩展思路:如何优化代码、处理更大范围的数字。


动手挑战:尝试修改代码,找出所有5位水仙花数(如54748),并在评论区分享你的结果!

路过的佬们点点关注哦~

你们的鼓励是我前进的动力~

----------------------------------------------end------------------------------------------

http://www.lryc.cn/news/532471.html

相关文章:

  • 两步构建 AI 总结助手,实现智能文档摘要
  • 承压金字塔(蓝桥杯17C)
  • day33-数据同步rsync
  • Android 实现首页Tab切换并且支持懒加载功能详解
  • [Android] 360行车记录仪谷歌版
  • 基于Redis分布式锁
  • Spring Boot 条件注解:@ConditionalOnProperty 完全解析
  • canny边缘检测
  • 团建 蓝桥杯省a 15
  • 【逻辑学导论】1.6 有效性和真实性
  • IDEA 中集成 Maven,配置环境、创建以及导入项目
  • Qt跨屏窗口的一个Bug及解决方案
  • Vue WebSocket简单应用 ws
  • 快速单机部署ollama v0.5.7 +openwebui(免去网络环境干扰)
  • 【华为OD-E卷 - 114 找最小数 100分(python、java、c++、js、c)】
  • 快速搭建GPU环境 | docker、k8s中使用gpu
  • VSCode设置——通过ctrl+鼠标滚动改变字体大小(新版本的vs)
  • 【kafka实战】06 kafkaTemplate java代码使用示例
  • Java 23新特性
  • bat脚本实现自动化漏洞挖掘
  • [创业之路-285]:《产品开发管理-方法.流程.工具 》-1- IPD的功能列表以及导入步骤
  • Redis命令:列表模糊删除详解
  • Day36-【13003】短文,数组的行主序方式,矩阵的压缩存储,对称、三角、稀疏矩阵和三元组线性表,广义表求长度、深度、表头、表尾等
  • 大数据sql查询速度慢有哪些原因
  • 文件 I/O 和序列化
  • 机器学习中的关键概念:通过SKlearn的MNIST实验深入理解
  • HELLOCTF反序列化靶场全解
  • 十二、Docker Compose 部署 SpringCloudAlibaba 微服务
  • VUE之插槽
  • 4. Go结构体使用