C语言水仙花数是指一个 N位正整数( N≥3),它的每个位上的数字的 N次幂之和等于它本身。 本题要求编写程序,计算所有N位水仙花数。
时间: 2023-12-11 22:32:36 浏览: 175
水仙花数是指一个 n 位数(n ≥ 3),它的每个位上的数字的 n 次幂之和等于它本身 例如,153 是一个水仙花数,因为 1^
```c
#include <stdio.h>
#include <math.h>
int main()
{
int n, i, j, sum, num;
scanf("%d", &n); // 输入位数
int start = pow(10, n - 1); // 计算起始数
int end = pow(10, n) - 1; // 计算结束数
for (i = start; i <= end; i++)
{
sum = 0;
num = i;
for (j = 0; j < n; j++)
{
sum += pow(num % 10, n); // 计算每个位数的N次方之和
num /= 10;
}
if (sum == i) // 判断是否为水仙花数
{
printf("%d\n", i);
}
}
return 0;
}
```
--相关问题--:
1. 如何判断一个数是否为质数?
2. 如何在C语言中实
阅读全文