目录
题目
打印所有的水仙花数,水仙花数:一个三位数,百位立方+十位立方+个位立方 = 原数 例如:153就是水仙花数
思路:
由于水仙花数是三位数,所以我们使用三个嵌套的循环来分别生成每一位数字的可能取值。
- 最外层循环控制百位数
i
,从 1 到 9 ,因为三位数的百位不能为 0 。- 中间层循环控制十位数
j
,从 0 到 9 。- 最内层循环控制个位数
k
,从 0 到 9 。对于每一组可能的三位数(由
i
、j
、k
组成),计算其百位的立方、十位的立方和个位的立方之和。同时,计算由这三个数字组成的实际三位数(
100 * i + 10 * j + k
)。通过条件判断,如果立方和等于实际的三位数,那么就说明这个数是水仙花数,使用
printf
函数将其打印出来。通过这种穷举的方式,遍历了所有可能的三位数组合,从而找出所有符合水仙花数定义的数并进行打印。
代码:
#include <stdio.h>
int main(int argc, char const *argv[])
{
for (int i = 1; i <= 9; i++) //三位数百位大于零 1~9
{
for (int j = 0; j <= 9; j++) //十位 0~9
{
for (int k = 0; k <= 9; k++) //个位 0~9
{
if (i * i * i + j * j * j + k * k * k == 100 * i + 10 * j + k)
{
printf("%d\n", i * i * i + j * j * j + k * k * k);
}
}
}
}
return 0;
}