判断一个三位水仙花数c语言
时间: 2024-09-25 20:00:17 浏览: 50
判断一个三位数是否是水仙花数,是指这个数各个位上的数字立方之和等于原数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
以下是用C语言编写的一个简单函数,用于检查输入的三位数是否是水仙花数:
```c
#include <stdio.h>
// 函数来计算数字各位上数字立方之和
int sumOfCubes(int num) {
int digits[4]; // 用于存储每一位的临时数组,这里假设四位数,但实际只需要三位
int sum = 0;
// 分割数字并求立方和
while (num > 0) {
digits[3] = num % 10; // 取最后一位
num /= 10;
sum += digits[3] * digits[3] * digits[3];
}
return sum;
}
// 主函数测试是否为水仙花数
int main() {
int num;
printf("请输入一个三位数: ");
scanf("%d", &num);
if (num >= 100 && num <= 999) { // 检查输入是否为三位数
if (sumOfCubes(num) == num) {
printf("%d 是一个水仙花数.\n", num);
} else {
printf("%d 不是水仙花数.\n", num);
}
} else {
printf("输入不是三位数!\n");
}
return 0;
}
```
在这个程序中,用户会被提示输入一个三位数,然后`sumOfCubes`函数会计算其各位的立方和,如果等于原数,则输出它是水仙花数,否则不是。
阅读全文