水仙花数:每个位上的数字的立方和,刚好等于该数字本身。那么就叫做水仙花数。且水仙花数一共有4个(153,370,371,407),并且是在【100,999】的三位数。
例如:153
1*1*1 + 5*5*5 + 3*3*3 = 1+125+27=153
所以要想求出水仙花数,那么我们需要按位数拆分。
例如:将153拆分成百位的1,十位的5,个位的3。然后比较每位上的三次方和是否与原三位数相等。如果相等就是水仙花数。
两种方法实现:
方法一:最简单的实现代码就是用三个for循环进行
用 a 表示百位,范围是:1-9;用 b 表示十位,范围是0-9;用 c 表示个位,范围是0-9
代码如下:
for a := 1; a < 10; a++ {
for b := 0; b < 10; b++ {
for c := 0; c < 10; c++ {
n := a*100 + b*10 + c*1
if a*a*a+b*b*b+c*c*c == n {
fmt.Println(n)
}
}
}
}
方法二:利用 math.Pow(x,y)方法。这个表达式表示:求 x 的 y 次方。不知道的小伙伴可以看一下这个博主的函数介绍:math.pow()函数用法_摸鱼飞弹的博客-CSDN博客_math.pow
以268为例:
268 268 /100 = 2 268 % 10 = 8 268 -->26 %10 = 6 268 -->68 /10 =6
代码如下:
for i := 100; i < 1000; i++ {
x := i / 100 //百位
y := i / 10 % 10 //十位
z := i % 10 //个位
if math.Pow(float64(x), 3)+math.Pow(float64(y), 3)+math.Pow(float64(z), 3) == float64(i) {
fmt.Println(i)
}
}