用c语言输出0到1000的水仙花数
时间: 2024-03-20 14:40:03 浏览: 18
水仙花数,指一个n位数(n>=3),其各位数字的n次方之和等于该数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
下面是用C语言输出0到1000之间的水仙花数的代码:
```c
#include <stdio.h>
int main() {
int i, j, k, n;
for (n = 100; n <= 1000; n++) {
i = n / 100; // 百位数
j = n / 10 % 10; // 十位数
k = n % 10; // 个位数
if (i * i * i + j * j * j + k * k * k == n) {
printf("%d\n", n);
}
}
return 0;
}
```
输出结果:
```
153
370
371
407
```
相关问题
用C语言输出所有的“水仙花数”
好的,以下是用 C 语言输出所有的“水仙花数”的程序:
```c
#include <stdio.h>
int main() {
int i, j, k;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
int num = i * 100 + j * 10 + k;
int sum = i * i * i + j * j * j + k * k * k;
if (num == sum) {
printf("%d\n", num);
}
}
}
}
return 0;
}
```
运行结果如下:
```
153
370
371
407
```
这个程序会输出所有的 3 位数中的“水仙花数”,即各个数位的立方和等于该数本身,例如 153=1^3+5^3+3^3。
c语言求0到n水仙花数
以下是求0到n的水仙花数的C语言代码:
```
#include <stdio.h>
#include <math.h>
int isNarcissistic(int num) {
int originalNum = num;
int n = 0;
double sum = 0;
while (originalNum != 0) {
originalNum /= 10;
++n;
}
originalNum = num;
while (originalNum != 0) {
int remainder = originalNum % 10;
sum += pow(remainder, n);
originalNum /= 10;
}
if ((int) sum == num) {
return 1;
} else {
return 0;
}
}
int main() {
int n;
printf("请输入n的值:");
scanf("%d", &n);
printf("0~%d的水仙花数有:\n", n);
for (int i = 0; i <= n; ++i) {
if (isNarcissistic(i)) {
printf("%d ", i);
}
}
return 0;
}
```
以上代码通过循环判断每个数字是否是水仙花数,并输出结果。水仙花数是指一个n位数字(n≥3),它的每个位上的数字的n次幂之和等于它本身。