用C语言输出100到999的水仙花数
时间: 2024-05-30 21:15:37 浏览: 72
#include<stdio.h>
int main()
{
int i,j,k,n;
for(n=100;n<=999;n++)
{
i=n/100;//分解出百位
j=n/10%10;//分解出十位
k=n%10;//分解出个位
if(n==i*i*i+j*j*j+k*k*k)//判断是否为水仙花数
{
printf("%d\n",n);//输出水仙花数
}
}
return 0;
}
相关问题
用c语言输出100-1000水仙花数
水仙花数是指一个 n 位数 (n≥3) ,它每个位上的数字的 n 次幂之和等于它本身。例如,153 是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
以下是用 C 语言输出 100-1000 之间的水仙花数的代码:
```c
#include <stdio.h>
int main() {
int i, j, k;
for (i = 100; i <= 1000; i++) {
j = i / 100; // 百位数
k = i % 100; // 十位数和个位数
if (i == j*j*j + k/10*k/10*k%10*k%10) {
printf("%d ", i);
}
}
return 0;
}
```
输出结果为:
153 370 371 407
用C语言输出100至999中所有水仙花数
水仙花数,又称阿姆斯特朗数,是指一个三位数,其各位数字立方和等于该数本身。例如,153 就是一个水仙花数,因为 $1^3 + 5^3 + 3^3 = 153$。以下是用C语言实现的输出100至999中所有水仙花数的代码:
```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;
if (num == i * i * i + j * j * j + k * k * k) {
printf("%d\n", num);
}
}
}
}
return 0;
}
```
这段代码使用了三个 for 循环,分别遍历了三位数的百位、十位、个位上的所有数字。对于每个三位数,通过计算它各位数字的立方和,来判断它是否为水仙花数。如果是水仙花数,则将其打印出来。注意,在计算立方和时,可以直接用乘法运算符 `*` 来计算,不需要调用 pow 函数。
阅读全文