编程输出所有的水仙花数,要求:用一个c语言函数调用实现水仙花数的判断。
时间: 2024-04-30 10:25:08 浏览: 16
水仙花数是指一个三位数,它的每个位上的数字的立方和等于它本身。例如:153是一个水仙花数,因为153=1³+5³+3³。
下面是一个用 C 语言实现的输出所有水仙花数的程序:
```c
#include <stdio.h>
int isNarcissistic(int num) {
int digit, sum = 0, tmp = num;
while (tmp > 0) {
digit = tmp % 10;
sum += digit * digit * digit;
tmp /= 10;
}
return (num == sum);
}
int main() {
int i;
printf("所有水仙花数:\n");
for (i = 100; i < 1000; i++) {
if (isNarcissistic(i)) {
printf("%d\n", i);
}
}
return 0;
}
```
该程序中的 `isNarcissistic` 函数用于判断一个数是否为水仙花数。在 `main` 函数中,我们循环遍历 100 到 999 之间的所有三位数,对每个数调用 `isNarcissistic` 函数进行判断,如果是水仙花数,则输出。
相关问题
判断水仙花数c语言程序调用函数
水仙花数是指一个 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;
}
```
在这个程序中,我们首先输入一个三位数,然后计算出它的位数。接下来,我们计算每个位上数字的幂次方和,并将结果与原数比较,以确定它是否为水仙花数。最后,程序输出相应的结果。
编程一个函数判断一个数是否是水仙花数。再在主函数中调用这个函数求出所有的水仙花数。(加上水仙花数的解释吧)用c语言
水仙花数,又叫自恋数或阿姆斯壮数,是指一个$n$位数($n>=3$),其各位数字的$n$次方和等于该数本身。例如:$1^3 + 5^3+ 3^3 =153$ 是一个$3$位的水仙花数。
以下是判断一个数是否是水仙花数的C语言函数代码:
```c
#include <stdio.h>
#include <math.h>
int isNarcissistic(int num){
int n = 0, digit, sum = 0, temp = num;
while(temp > 0){ //计算num的位数
temp = temp / 10;
n++;
}
temp = num;
while(temp > 0){ //计算num各位数字的n次方和
digit = temp % 10;
sum += pow(digit, n);
temp /= 10;
}
return (sum == num); //判断num是否为水仙花数
}
```
在主函数中调用该函数,可以得到所有的水仙花数:
```c
int main(){
int i;
for(i = 100; i < 1000; i++){ //枚举所有三位数
if(isNarcissistic(i)){ //判断是否为水仙花数
printf("%d ", i); //输出水仙花数
}
}
return 0;
}
```