码迷,mamicode.com
首页 > 其他好文 > 详细

练习_(4)求1000以内的水仙花数,及扩展思路。

时间:2018-06-13 11:33:52      阅读:131      评论:0      收藏:0      [点我收藏+]

标签:str   val   out   调用   method   练习   generated   bubuko   alt   

//判断是否是水仙花数
//水仙花数是指一个 n 位数(n≥3 ),
//它的每个位上的数字的 n 次幂之和等于它本身(例如:1^3 + 5^3+ 3^3 = 153)。

//获取1000以内的水仙花数

思路:1000以内的数是都三位数,只要控制循环到1000然后风别获取到这个数的个位十位百位乘以三次幂再相加判断是否等于这个数。

代码如下:

/*
 * 获取1000以内的水仙花数
 */
public class isNarcissus {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        for(int i=100;i<1000;i++){
            int a = i%10;//个位数
            int b = i/10%10;//十位数
            int c = i/100%10;//百位数
            if ( (a*a*a + b*b*b + c*c*c)==i  ) {
                System.out.print(i+" ");
            }
        }

    }

}

结果:
技术分享图片

1000以内的水仙花数我们求出来了,那么如果要求10000以内,100000以内的水仙花数怎么求,封装一个类,

//计算自幂数
public class Narcissuses {
    private int value;

    public int getValue() {
        return value;
    }

    public void setValue(int value) {
        this.value = value;
    }
    
    public boolean isNarcissuser(){
        int count=(value+"").length();//保存位数
        int vae=value;//备份    
        int sum=0;//保存结果;
        int a=0;//保存个位
        while(value>0){
            int b=1;   //保存每位数幂次发后结果
            a=value%10;//得到个位
            for(int i=0;i<count;i++){
                b*=a;//计算幂数
            }
            sum+=b;//结果相加
            value/=10;//循环结束,准备下一位数的幂数获取
        }
        //判断结果是否等于本身。
        if(sum==vae){
            return true;
        }
        return false;
    }

}

调用这个类

 1 public class NarcissuseMain {
 2 
 3     public static void main(String[] args) {
 4         // TODO Auto-generated method stub
 5 Narcissuses ns=new Narcissuses();
 6 //求1000以内的自幂数
 7 for (int i = 100; i < 999; i++) {
 8 ns.setValue(i);
 9 if(ns.isNarcissuser()){
10     System.out.print(i+" ");
11     
12         }
13       }
14 
15     }
16   }

结果: 

技术分享图片

技术分享图片

练习_(4)求1000以内的水仙花数,及扩展思路。

标签:str   val   out   调用   method   练习   generated   bubuko   alt   

原文地址:https://www.cnblogs.com/bingxuewangjue/p/9175931.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!