【自己编的c语言水仙花数】在学习C语言的过程中,很多初学者都会尝试编写一些经典的算法题,比如“水仙花数”。水仙花数(Narcissistic number)也被称为自恋数、自幂数或阿姆斯特朗数,是指一个n位数,其各位数字的n次幂之和等于该数本身。例如:153 是一个三位数的水仙花数,因为 1³ + 5³ + 3³ = 153。
以下是我自己编写的一个C语言程序,用于找出所有三位数中的水仙花数,并对结果进行总结。
一、程序说明
本程序通过循环遍历所有三位数(100~999),分别提取每一位上的数字,计算它们的立方和,然后判断是否与原数相等。若相等,则输出该数。
代码如下:
```c
include
int main() {
int i, a, b, c;
printf("三位数的水仙花数有:\n");
for (i = 100; i <= 999; i++) {
a = i / 100; // 百位
b = (i / 10) % 10; // 十位
c = i % 10;// 个位
if (a a a + b b b + c c c == i) {
printf("%d\n", i);
}
}
return 0;
}
```
二、运行结果总结
运行上述程序后,可以得到以下三位数的水仙花数:
水仙花数 |
153 |
370 |
371 |
407 |
三、结论
通过自己编写C语言程序,不仅加深了对循环结构、条件判断以及数学运算的理解,还进一步掌握了如何处理数字的各个位数。水仙花数虽然看似简单,但却是学习编程中非常实用的例子,能够帮助初学者更好地理解程序逻辑和算法实现。
此外,这种练习方式也有助于提高调试能力和问题解决能力,是编程入门阶段不可或缺的一部分。