用c语言求出所有的水仙花数。
时间: 2024-10-21 19:04:52 浏览: 30
在C语言中,水仙花数是指那些每个位上的数字立方之和等于原数本身的三位数。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
下面是一个简单的程序示例,用于找出所有小于1000的水仙花数:
```c
#include <stdio.h>
// 函数定义,检查一个数字是否是水仙花数
int is_armstrong(int num) {
int original_num, remainder, sum = 0;
original_num = num;
// 对每一位进行立方并加总
while (original_num != 0) {
remainder = original_num % 10;
sum += remainder * remainder * remainder; // 取余并立方
original_num /= 10;
}
// 检查是否相等
if (sum == num)
return 1; // 是水仙花数
else
return 0; // 否则不是
}
// 主函数遍历并打印水仙花数
void find_armstrong_numbers() {
for (int i = 100; i < 1000; ++i) { // 遍历三位数范围
if (is_armstrong(i))
printf("%d ", i); // 打印水仙花数
}
}
int main() {
find_armstrong_numbers();
return 0;
}
```
当你运行这个程序,它会输出153, 370, 371, 407 这些水仙花数。
阅读全文