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);
}
}
}
}
标签:10,153,Java,递归,int,System,println,水仙花 来源: https://blog.csdn.net/m0_62218217/article/details/121483257