文章目录
(二)拓展练习
任务1、打印水仙花数
所谓水仙花数,是指等于其各位数字立方和的三位数。
153=13+53+33
370=33+73+03
371=33+73+13
407=43+03+73
分析问题,首先水仙花数是三位数,那么我们可以确定范围:[100, 999],这个我们可以通过循环结构来搞定:
for (int n = 100; n <= 999; n++) {
...
}
然后对于这个范围的每个数n,我们要去判断它是否等于其各位数字的立方和,这里的难点或关键在于如何分解一个三位数,得到它的每位数字。
假设我们已经把三位数n分解成百位数p3,十位数p2,个位数p1,这样我们的筛选条件就可以写出来:n == p3 * p3 * p3 + p2 * p2 * p2 + p1 * p1 * p1。
如何拆分一个三位数n(375)呢?
首先求n的个位数:n % 10 = 375 % 10 = 5
然后要将三位数变成两位数:n = n / 10 = 375 / 10 = 37;
对于新的两位数n,又求它的个位数:n % 10 = 37 % 10 = 7
然后要将两位数变成一位数:n = n / 10 = 37 / 10 = 3;
我们可以