c语言随机数判断是否为水仙花数
时间: 2024-10-24 13:14:59 浏览: 29
在C语言中,水仙花数是一种特殊的三位数,其各位数字立方之和等于该数本身。比如153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
判断一个整数是否为水仙花数的基本步骤如下:
1. 定义一个函数,接受一个整数作为输入参数。
2. 检查该数是否为三位数,如果不是则直接返回false。
3. 分别获取这个数的百位、十位和个位数字。可以除以100取余数得到百位,再除以10取余数得到十位,最后就是个位。
4. 计算每个位置数字的立方,并加总起来。
5. 判断计算出的和是否等于原始输入的数,如果相等,则是水仙花数,返回true;否则,返回false。
下面是一个简单的C语言函数实现示例:
```c
#include <stdio.h>
#include <stdbool.h>
bool isArmstrong(int num) {
if (num < 100 || num > 999) {
return false; // 如果不是三位数,直接返回false
}
int digit1, digit2, digit3;
digit1 = num / 100; // 百位
digit2 = (num % 100) / 10; // 十位
digit3 = num % 10; // 个位
int sumOfCubes = digit1 * digit1 * digit1 + digit2 * digit2 * digit2 + digit3 * digit3 * digit3;
return sumOfCubes == num; // 如果和等于原数,是水仙花数
}
int main() {
int number;
printf("Enter a three-digit number: ");
scanf("%d", &number);
if (isArmstrong(number)) {
printf("%d is an Armstrong number.\n", number);
} else {
printf("%d is not an Armstrong number.\n", number);
}
return 0;
}
```
阅读全文