c语言解决题目描述 如果一个三位数n � 的各位数字的立方和等于n � ,那么称n � 为水仙花数。例如153=13+53+33 153 = 1 3 + 5 3 + 3 3 ,因此153是水仙花数。 给定两个正整数a � 、b � ,输出在闭区间[a,b] [ � , � ] 内的所有水仙花数。 输入描述 两个正整数a � 、b � (100≤a≤b≤999 100 ≤ � ≤ � ≤ 999 )。 输出描述 在一行里输出闭区间[a,b] [ � , � ] 内的所有水仙花数,多个水仙花数按从小到大的顺序输出,中间用空格隔开,行末不允许有多余的空格。如果区间内没有水仙花数,那么输出NO
时间: 2024-01-20 12:04:17 浏览: 116
以下是 C 语言的解法:
```c
#include <stdio.h>
int main() {
int a, b;
scanf("%d %d", &a, &b);
int i, j, k;
int count = 0; // 记录水仙花数的个数
for (i = a; i <= b; i++) {
j = i / 100; // 百位
k = i % 10; // 个位
if (j * j * j + (i / 10 % 10) * (i / 10 % 10) * (i / 10 % 10) + k * k * k == i) {
// 如果各位数字的立方和等于这个数本身,那么这个数是水仙花数
count++;
if (count == 1) {
printf("%d", i);
} else {
printf(" %d", i);
}
}
}
if (count == 0) {
printf("NO");
}
return 0;
}
```
首先读入两个正整数 a 和 b,然后使用 for 循环遍历闭区间 [a,b] 中的每一个数。对于每一个数,将它的百位、十位和个位分别计算出来,然后判断各位数字的立方和是否等于这个数本身。如果相等,则输出这个数;否则继续遍历下一个数。
需要注意的是,如果闭区间 [a,b] 内没有水仙花数,那么需要输出 NO。
阅读全文
相关推荐



















