使用c语言编出所有水仙花数
时间: 2024-02-21 20:35:15 浏览: 20
水仙花数是指一个三位数各个位上的数字的立方和等于该数本身。例如,153是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。以下是使用 C 语言编写的程序,用于查找所有的水仙花数。
```c
#include <stdio.h>
int main() {
int i, j, k, num;
printf("所有的水仙花数:\n");
for (num = 100; num <= 999; num++) {
i = num / 100; // 获取百位数
j = (num / 10) % 10; // 获取十位数
k = num % 10; // 获取个位数
if (num == i*i*i + j*j*j + k*k*k) {
printf("%d\n", num);
}
}
return 0;
}
```
程序首先定义了三个变量 i、j 和 k,分别用于存储水仙花数的百位数、十位数和个位数。然后使用循环枚举所有的三位数,计算该数的立方和,并将其与该数本身进行比较。如果相等,则输出该数,即为一个水仙花数。
相关问题
用C语言打印出所有水仙花数
水仙花数是指一个n位数(n≥3),其各位数字的n次方之和等于该数本身。例如153=1^3+5^3+3^3,所以153是一个水仙花数。
以下是用C语言打印出所有水仙花数的代码:
```c
#include <stdio.h>
int main() {
int i, j, k, num;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
num = i * 100 + j * 10 + k;
if (num == i * i * i + j * j * j + k * k * k) {
printf("%d\n", num);
}
}
}
}
return 0;
}
```
该程序的思路是通过三层循环依次枚举所有的三位数,计算出该数的各位数字的立方和,判断是否等于该数本身,如果是则输出该数。
用c语言求出所有水仙花数
水仙花数是指一个n位数(n>=3),它的每个位上的数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为$1^3+5^3+3^3=153$。
以下是用C语言编写的求解所有水仙花数的程序:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int i, j, k, n, sum;
printf("所有的水仙花数为:\n");
for (n = 100; n <= 999; n++) {
i = n / 100; // 分解百位数
j = (n / 10) % 10; // 分解十位数
k = n % 10; // 分解个位数
sum = pow(i, 3) + pow(j, 3) + pow(k, 3); // 计算每个位上数字的立方和
if (n == sum) {
printf("%d ", n);
}
}
return 0;
}
```
程序运行结果:
```
所有的水仙花数为:
153 370 371 407
```