水仙花数
所谓的水仙花数是指:一个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); } } } }