判断水仙花数c语言程序调用函数
时间: 2023-09-18 12:14:29 浏览: 118
水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。例如,153 是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
以下是一个判断水仙花数的 C 语言程序,其中调用了 pow() 函数来计算幂次方:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int num, originalNum, remainder, n = 0;
double result = 0.0;
printf("输入一个三位数:");
scanf("%d", &num);
originalNum = num;
// 计算位数
while (originalNum != 0) {
originalNum /= 10;
++n;
}
originalNum = num;
// 计算幂次方和
while (originalNum != 0) {
remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
// 比较结果与原数
if ((int)result == num)
printf("%d 是一个水仙花数。\n", num);
else
printf("%d 不是一个水仙花数。\n", num);
return 0;
}
```
在这个程序中,我们首先输入一个三位数,然后计算出它的位数。接下来,我们计算每个位上数字的幂次方和,并将结果与原数比较,以确定它是否为水仙花数。最后,程序输出相应的结果。
阅读全文