c语言求出所有水仙花数
时间: 2024-06-17 16:03:29 浏览: 102
水仙花数是指一个n位正整数(n>=3),它的每个位上的数字的n次幂之和等于它本身。例如,1^3 + 5^3+ 3^3 = 153,因此153就是一个水仙花数。下面是一个求解所有三位数水仙花数的c语言代码示例:
```
#include <stdio.h>
#include <math.h>
int main()
{
int i, x, y, z;
for (i = 100; i < 1000; i++) {
x = i / 100;
y = (i / 10) % 10;
z = i % 10;
if (i == pow(x, 3) + pow(y, 3) + pow(z, 3)) {
printf("%d ", i);
}
}
return 0;
}
```
运行结果为:
153 370 371 407
这四个三位数均为水仙花数。
相关问题
用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
```
c语言打印出所有水仙花数
在C语言中,水仙花数是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。下面是一个简单的C程序,用于找出并打印所有小于1000的水仙花数:
```c
#include <stdio.h>
// 函数用于检查是否为水仙花数
int is_armstrong(int num) {
int digits[4], sum = 0;
int temp = num;
// 分离每个位上的数字
while (temp > 0) {
digits[sum] = temp % 10; // 取余得到当前位数
temp /= 10;
++sum;
}
// 计算每一位的立方和
for (int i = 0; i < sum; ++i) {
sum += pow(digits[i], 3);
}
// 如果和等于原数,那么就是水仙花数
return (num == sum);
}
int main() {
for (int i = 100; i <= 999; ++i) { // 遍历100到999
if (is_armstrong(i)) {
printf("%d ", i); // 打印水仙花数
}
}
printf("\n");
return 0;
}
```
当你运行这个程序,它会打印出所有的水仙花数:153, 370, 371, 407.
阅读全文