java_水仙花数算法

这是我一哥们的面试题,很多人突然看到会手足无措,不要紧张,我们一步一步分析,其实很简单。
题目:打印出100-999之间所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。
  例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方 
  1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
public class ShuiXianHua {
    public static void main(String[] args) {
        //算出100-999之间的水仙花数
        //  百位数   十位数  个位数
        int baiwei,shiwei,gewei;
        for (int i =100; i <=999; i++) {
            baiwei=i/100;//因为是int型,所以除以100后还是只保留整数位。
            shiwei=(i-baiwei*100)/10;
            gewei=i-baiwei*100-shiwei*10;
        //用Math类中的pow方法求出三个数的3次方,但返回值是double类型的,所以前面加上int强制转换。
            int b=(int)Math.pow(baiwei,3);
            int s=(int)Math.pow(shiwei,3);
            int g=(int)Math.pow(gewei,3);
            /*if(i==baiwei*baiwei*baiwei+shiwei*shiwei*shiwei+gewei*gewei*gewei){
                System.out.println(i);
            }*/
            if(i==b+s+g){
                    System.out.println(i);
            }
        }
    }
}

这个编的很详细,希望对大家有帮助,同时也能见证我成长的过程。

  

你可能感兴趣的:(java_水仙花数算法)