Java 水仙花数 两种方法(递归&循环)

水仙花数

所谓的水仙花数是指:一个n位数( n23 ),它的每个位上的数字的n 次所谓的水仙花数是指:一个n位数(N23),它的每个位上的数字的n次幂之和等于它本身幂之和等于它本身。

例如:153,370,371,407等都是水仙花数,就拿153来说,153 =1*1*1 +5*5*5 +3*3*3. 幂之和等于它本身.例如153,370,371,407等都是水仙花数,就拿153来说,153=1*1*1+5*5+3*3。

满足上面的条件就是水仙花数,否则不是。在编写代码的过程中,重点是如何分 满足上面的条件就是水仙花数,否则不是.在编写代码的过程中,重点是如何分解,如何表达出数字中的个位,十位,百位等。在这里定义三个整型(int)变量: int a,b,c.

a=i%10             //分解出各位

b=i/10%10        //分解出十位

c=i/100%10      //分解出百位

public class Test44 {
    public static void main(String[] args) {
        System.out.println("循环方法");
        isQui1();
        System.out.println("递归方法");
        int i=100;
        isQui2(i);
    }
    //方法二(递归)
    private static int isQui2(int i) {
        if(i!=1000) {
            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){
                System.out.println(i);
            }
            return isQui2(i+1);
        }
        return 0;
    }

    //方法一(循环)
    private static void isQui1() {
        for (int i = 100; i < 1000; 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){
                System.out.println(i);
            }
        }
    }
}

猜你喜欢

转载自blog.csdn.net/m0_62218217/article/details/121483257