C语言只用循环判断是否为水仙花数
时间: 2024-12-17 08:16:32 浏览: 13
在C语言中,判断一个数是否为水仙花数(也称为 narcissistic number 或 pluperfect digital invariant),就是看它的各个位数字的立方和是否等于它本身。这里我们可以使用一个简单的循环结构来实现:
```c
#include <stdio.h>
#include <stdbool.h>
bool isNarcissistic(int num) {
int digits[10]; // 存储每一位数字
int sum = 0;
int originalNum;
// 将num分解为个位、十位、百位...并存入digits数组
while (num > 0) {
digits[num % 10] += sum; // 避免进位影响当前位
sum *= 10;
originalNum = num;
num /= 10;
}
// 计算每位数字的立方和并与原始数比较
for (int i = 0; i <= 9; i++) {
if (digits[i] != (originalNum / (int)pow(10, i))) { // 检查是否满足水仙花条件
return false;
}
}
return true;
}
int main() {
int input;
printf("请输入一个整数:");
scanf("%d", &input);
if (isNarcissistic(input)) {
printf("%d 是水仙花数。\n", input);
} else {
printf("%d 不是水仙花数。\n", input);
}
return 0;
}
```
这段代码首先将输入的数字分解成各位数字,并累加进位,然后计算每个位置的立方和。循环内对比原数的各个位和立方和是否相等,如果不等则返回false,否则返回true。
阅读全文