C语言输出水仙花数。输入一个正整数n,输出所有的n位水仙花数
时间: 2023-05-12 21:04:11 浏览: 87
以下是C语言代码,可以输出n位水仙花数:
```c
#include <stdio.h>
#include <math.h>
int main() {
int n, i, j, k, sum;
printf("请输入一个正整数n:");
scanf("%d", &n);
for (i = pow(10, n-1); i < pow(10, n); i++) {
sum = 0;
j = i;
while (j > 0) {
k = j % 10;
sum += pow(k, n);
j /= 10;
}
if (sum == i) {
printf("%d\n", i);
}
}
return 0;
}
```
这个程序会输出所有n位水仙花数,例如输入3,输出的结果为:
```
153
370
371
407
```
相关问题
c语言输入一个正整数n,计算n位水仙花数。
水仙花数是指一个n位正整数,其各位数字的n次方之和等于该数本身。例如,153是一个三位水仙花数,因为1^3+5^3+3^3=153。
以下是C语言代码实现:
```c
#include <stdio.h>
#include <math.h>
int main() {
int n, i, j, num, sum;
printf("请输入位数n:");
scanf("%d", &n);
printf("%d位水仙花数有:\n", n);
for (i = pow(10, n - 1); i < pow(10, n); i++) { //循环枚举n位数
num = i;
sum = 0;
for (j = 0; j < n; j++) { //计算每一位数字的n次方之和
sum += pow(num % 10, n);
num /= 10;
}
if (sum == i) { //如果满足水仙花数定义,输出该数
printf("%d ", i);
}
}
return 0;
}
```
在此代码中,首先通过scanf函数输入位数n,然后利用for循环枚举n位数。对于每一个枚举到的数,利用另一个for循环计算其各位数字的n次方之和。最后,如果该数等于各位数字的n次方之和,即满足水仙花数的定义,就输出该数。
用c语言输出n位水仙花数
水仙花数是指一个n位数,它的每个位上的数字的n次幂之和等于它本身。例如,153是一个3位数,它的每个位上的数字的3次幂之和等于它本身,即1^3 + 5^3 + 3^3 = 153。下面是一个用C语言输出n位水仙花数的示例代码:
```c
#include <stdio.h>
#include <math.h>
int main() {
int n, i, j, sum, num;
printf("请输入一个正整数n:");
scanf("%d", &n);
printf("%d位水仙花数有:\n", n);
for (i = pow(10, n - 1); i < pow(10, n); i++) {
sum = 0;
num = i;
for (j = 1; j <= n; j++) {
sum += pow(num % 10, n);
num /= 10;
}
if (sum == i) {
printf("%d ", i);
}
}
printf("\n");
return 0;
}
```
运行程序后,输入一个正整数n,程序会输出n位水仙花数。例如,当n为3时,输出结果为:
```
请输入一个正整数n:3
3位水仙花数有:
153 370 371 407
```