如何用C语言编写一个函数来判断一个整数是否为水仙花数(即一个三位数,其各位数字立方和等于该数本身)?
时间: 2024-10-28 18:07:06 浏览: 58
在C语言中,你可以编写一个函数来检查一个整数是否是水仙花数。下面是一个简单的函数示例:
```c
#include <stdio.h>
#include <math.h> // 需要包含这个头文件来使用pow()函数计算立方
// 函数声明
int is_armstrong(int num);
int main() {
int number;
printf("请输入一个三位数:");
scanf("%d", &number);
if (is_armstrong(number)) {
printf("%d 是水仙花数。\n", number);
} else {
printf("%d 不是水仙花数。\n", number);
}
return 0;
}
// 判断是否是水仙花数的函数
int is_armstrong(int num) {
int original_num = num; // 备份原数以便取各位数字
int sum = 0;
while (num > 0) {
int digit = num % 10; // 取出最后一位
sum += pow(digit, 3); // 立方并累加
num /= 10; // 移除最后一位
}
// 如果原数等于各位数字立方之和,则是水仙花数
return original_num == sum;
}
```
在这个程序中,我们首先输入一个三位数,然后通过`is_armstrong()`函数来检查它的每位数字立方和是否等于原始数值。如果是,则返回`true`,表示它是水仙花数;否则,返回`false`。
阅读全文
相关推荐
![c](https://img-home.csdnimg.cn/images/20250102104920.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)