使用C语言,列举出0-1000以内的水仙花数,
时间: 2024-10-14 18:12:29 浏览: 36
水仙花数是一种特殊的整数,它的各位数字立方之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。在C语言中,我们可以编写一个循环来找出所有0-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 == original_num)
return 1; // 如果相等则返回1,表示是水仙花数
else
return 0; // 否则返回0
}
int main() {
for (int i = 0; i <= 1000; ++i) {
if (is_armstrong(i))
printf("%d ", i); // 打印找到的水仙花数
}
return 0;
}
```
这个程序会打印出0到1000之间的所有水仙花数。
阅读全文