c语言判断一个整数是否是水仙花数
时间: 2024-09-29 14:04:37 浏览: 36
水仙花数是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
在C语言中判断一个整数是否是水仙花数,可以编写如下的函数:
```c
#include <stdio.h>
#include <stdbool.h>
bool isArmstrong(int num) {
int original_num, remainder, sum = 0;
// 检查是否为三位数
if (num < 100 || num > 999) {
return false;
}
original_num = num;
// 把数字拆分成每一位
while (original_num != 0) {
remainder = original_num % 10;
sum += pow(remainder, 3); // 计算每位数的立方并累加
original_num /= 10;
}
// 如果原数等于它的各部分立方和,则返回true,表示是水仙花数;否则返回false
return sum == num;
}
int main() {
int input;
printf("请输入一个三位数:");
scanf("%d", &input);
if (isArmstrong(input)) {
printf("%d 是一个水仙花数。\n", input);
} else {
printf("%d 不是水仙花数。\n", input);
}
return 0;
}
```
阅读全文