C语言输出所有的“水仙花数”,所谓“水仙花数”是指一个3位数,其各位数字立方和等于该数字本身。例如,153是一个水仙花数,因为153=1^3+5^3+3^3
时间: 2024-10-22 14:09:03 浏览: 103
在C语言中,可以编写一段程序来找出所有的水仙花数。首先,我们需要遍历从100到999的所有三位数,然后计算每个数各位数字的立方和,如果和等于原数本身,则认为它是水仙花数。以下是简单的C代码实现:
```c
#include <stdio.h>
#include <stdbool.h>
bool isArmstrong(int num) {
int original = num;
int sum = 0;
while (num != 0) {
int digit = num % 10;
sum += digit * digit * digit;
num /= 10;
}
return original == sum;
}
int main() {
for (int i = 100; i <= 999; ++i) {
if (isArmstrong(i)) {
printf("%d 是一个水仙花数。\n", i);
}
}
return 0;
}
```
在这个程序中,`isArmstrong`函数用于检查一个数是否是水仙花数,`main`函数则循环遍历并打印出符合条件的数。
相关问题
c语言输出所有水仙花数。所谓水仙花数是指一个3位数,其各位数字的立方和等于该数本身。
A:
```c
#include <stdio.h>
int main() {
int i, j, k;
for (i = 1; i < 10; i++) {
for (j = 0; j < 10; j++) {
for (k = 0; k < 10; k++) {
int num = i * 100 + j * 10 + k;
int sum = i * i * i + j * j * j + k * k * k;
if (num == sum) {
printf("%d\n", num);
}
}
}
}
return 0;
}
```
输出结果:
```
153
370
371
407
```
解释:
在三重循环中,分别枚举百位、十位和个位上可能的数字。对于每个三位数,计算其各位数字的立方和,并将结果与这个三位数本身进行比较。如果相等,则输出这个三位数。
C语言输出所有的“水仙花数”,所谓“水仙花数”是指一个3位数,其各位数字立方和等于该数字本身
#include <stdio.h>
int main() {
int i, j, k, n;
for (n = 100; n <= 999; n++) {
i = n / 100; // 百位数
j = (n / 10) % 10; // 十位数
k = n % 10; // 个位数
if (n == i * i * i + j * j * j + k * k * k) {
printf("%d\n", n);
}
}
return 0;
}
阅读全文
相关推荐

















