用c语言计算水仙花数
时间: 2023-12-25 07:27:27 浏览: 93
C语言实现水仙花数查找算法及其应用
水仙花数是指一个n位数(n>=3),它的每个位上的数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
以下是用C语言计算水仙花数的代码:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int n, i, num, sum;
printf("请输入一个正整数n:");
scanf("%d", &n);
printf("所有的%d位水仙花数为:\n", n);
for (i = pow(10, n-1); i < pow(10, n); i++)
{
num = i;
sum = 0;
while (num > 0)
{
sum += pow(num % 10, n);
num /= 10;
}
if (sum == i)
{
printf("%d\n", i);
}
}
return 0;
}
```
代码解释:
1. 首先,我们需要输入一个正整数n,表示要计算n位的水仙花数。
2. 然后,我们使用for循环遍历所有n位数,从10^(n-1)到10^n-1。
3. 在循环中,我们将当前数字num赋值为i,然后使用while循环计算num的每一位数字的n次幂之和sum。
4. 如果sum等于i,则说明i是一个水仙花数,我们将其输出即可。
阅读全文