水仙花数c 语言
时间: 2023-07-13 20:22:55 浏览: 51
水仙花数是指一个n位数(n≥3),它每个位上的数字的n次幂之和等于它本身。例如,153是一个三位数,它的每个位上的数字的3次幂之和等于153。
以下是用C语言实现找出所有三位数的水仙花数的代码:
```c
#include <stdio.h>
#include <math.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 (n == pow(i, 3) + pow(j, 3) + pow(k, 3)) {
printf("%d\n", n);
}
}
return 0;
}
```
输出结果为:
```
153
370
371
407
```
这四个数都是三位数的水仙花数。
相关问题
c 循环结构寻找水仙花数
以下是使用C语言循环结构寻找水仙花数的代码示例:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int n, i, j, k, sum;
printf("水仙花数有: ");
for (n = 100; n < 1000; n++) {
i = n / 100; // 百位数
j = n / 10 - i * 10; // 十位数
k = n % 10; // 个位数
sum = pow((double)i, 3) + pow((double)j, 3) + pow((double)k, 3);
if (n == sum) {
printf("%d ", n);
}
}
printf("\n"); return 0;
}
```
该程序使用for循环从100到999遍历所有三位数,然后将每个数的百位、十位和个位分别计算出来,再将它们的立方和计算出来。如果该立方和等于该数本身,则说明该数是水仙花数,将其输出即可。
水仙花数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, num, sum, i;
printf("请输入一个三位数:");
scanf("%d", &num);
n = 3; // 水仙花数是三位数
sum = 0;
for (i = 1; i <= n; i++) {
int digit = num % 10;
sum += pow(digit, n);
num /= 10;
}
if (sum == num) {
printf("%d 是一个水仙花数\n", num);
} else {
printf("%d 不是一个水仙花数\n", num);
}
return 0;
}
```
运行时,程序会要求输入一个三位数,然后判断它是否是一个水仙花数并输出结果。