C语言编写函数判断水仙花数
时间: 2024-06-13 21:07:47 浏览: 140
以下是用C语言编写的判断水仙花数的函数:
```c
int isNarcissistic(int num) {
int sum = 0, temp = num, digit = 0;
while (temp > 0) {
digit = temp % 10;
sum += pow(digit, 3);
temp /= 10;
}
if (sum == num) {
return 1;
} else {
return 0;
}
}
```
该函数接受一个整数参数num,返回值为1表示num是水仙花数,返回值为0表示num不是水仙花数。函数内部使用while循环和pow函数计算num的每一位的立方和,最后与num比较判断是否为水仙花数。
相关问题
c语言用函数求水仙花数
以下是使用C语言编写的函数来求水仙花数的示例代码:
```c
#include <stdio.h>
#include <math.h>
int isArmstrong(int num) {
int originalNum, remainder, n = 0, result = 0;
originalNum = num;
// 计算数字的位数
while (originalNum != 0) {
originalNum /= 10;
++n;
}
originalNum = num;
// 计算每位数字的n次幂并求和
while (originalNum != 0) {
remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
// 判断是否为水仙花数
if (result == num)
return 1;
else
return 0;
}
int main() {
int start, end;
printf("请输入范围: ");
scanf("%d %d", &start, &end);
printf("水仙花数: ");
for (int i = start; i <= end; i++) {
if (isArmstrong(i))
printf("%d ", i);
}
return 0;
}
```
用C语言编写一个函数求水仙花数
当然,我可以帮你编写一个 C 语言函数来求水仙花数。水仙花数是指一个 n 位数( n>=3 ),它的每个位上的数字的 n 次幂之和等于它本身。例如,153 就是一个 3 位的水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
下面是一个求水仙花数的 C 语言函数的示例代码:
```c
#include <math.h>
int is_narcissistic_number(int num) {
int sum = 0, n = 0, temp = num;
while (temp > 0) {
temp /= 10;
n++;
}
temp = num;
while (temp > 0) {
sum += pow(temp % 10, n);
temp /= 10;
}
return sum == num;
}
```
这个函数的参数是一个整数 `num`,它会返回一个整数值,如果 `num` 是一个水仙花数,则返回 1,否则返回 0。
这个函数中用到了 `pow()` 函数来计算幂次方。函数中首先计算出 `num` 的位数,然后逐位计算每个数位的幂次方并求和,最后判断和是否等于 `num`。
希望这个代码能够帮到你!
阅读全文