c语言 判断水仙花数
时间: 2024-10-21 15:01:14 浏览: 52
C语言变种水仙花数.zip
在C语言中,判断一个数字是否为“水仙花数”通常是指这个数的每一位立方之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。以下是一个简单的C程序,可以用来检查输入的整数是否为水仙花数:
```c
#include <stdio.h>
int is narcissistic_number(int num) {
int digits[10], sum = 0;
// 将数字分解成各个位
while(num != 0) {
digits[sum++] = num % 10;
num /= 10;
}
// 计算每个位立方的总和并与原数比较
for (int i = 0; i < sum; i++) {
if (digits[i] * digits[i] * digits[i] != digits[i]) {
return 0; // 如果有不符合水仙花规则的位,返回false
}
}
return sum == 3; // 返回 true 只有当有3位数字并且都满足规则时
}
int main() {
int number;
printf("请输入一个三位数:");
scanf("%d", &number);
if(is_narcissistic_number(number)) {
printf("%d 是水仙花数。\n", number);
} else {
printf("%d 不是水仙花数。\n", number);
}
return 0;
}
```
这段代码首先将输入的数字拆分成各个位,然后计算每个位的立方并检查是否等于该位,如果发现有一个不满足条件则立即返回0(表示不是水仙花数)。最后,如果所有位都满足条件,且共有3位,就返回true。
阅读全文