目录
- 1 题目
- 2 分析
- 3 实现
- 4 运行结果
1 题目
打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数 本身。例如: 153 153 153是一个"水仙花数",因为 153 = 1 3 + 5 3 + 3 3 153=1^3+5^3+3^3 153=13+53+33
2 分析
本题中限制数的范围为三位数,那么使用
for
循环遍历的时候范围为100~999,然后用除法和取余操作将每个数的百位、十位、个位分离出来,然后将三个分离出来的数取三次方,再与原来的数比较,若相等,则就符合题意
3 实现
#include <stdio.h>
int main() {
for (int i = 100; i <= 999; i++) {
int a = i % 10; // 分离出个位
int b = i / 10 % 10; // 分离出十位
int c = i / 100 % 10; // 分离出百位
if (i == (a*a*a + b*b*b + c*c*c)) {
printf("%d\n", i);
}
}
return 0;
}
4 运行结果
153
370
371
407