1. 问题描述
水仙花数也被称为超完全数字不变数、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数,水仙花数是指一个3位数,它的每个位上的数字的3次幂之和等于它本身。
1、水仙花数是一个三位数:111 333 456 999 530
2、水仙花数的个位、十位、百位的数字立方和等于原数
小伙伴们看了问题描述后,一定要自己先练习,再去看博主的代码和解题思路,才能提高自己的编程水平,全靠自觉哟!!!
2. 问题分析
怎么获取个位、十位、百位上的数?
- 个位数
371 :就是原始数字对10进行取余的运算结果 371 % 10 = 1
- 十位数
371:371通过除以10,可以将7移动到个位上去(整数):371 // 10 = 37
37:37对10进行取余可以得到最后一位的值7 :37 % 10 = 7
- 百位数
371:3就是原始数字除以100的结果(整除):371 // 100 = 3
- 思考:任意数字的指定位置上的数值如何求?
123456789:先10000得到12345;再对10取余得到5
3. 算法思路
1. 使用循环从100开始到999结束
2. 每次的循环体内,获取百位数数字、十位数数字、个位数数字
3. 判断百位数数字三次方加十位数数字的三次方加个位数数字的三次方是否等于它本身,如果是就是水仙花数。
4. 代码实现
for循环代码实现
实现代码