HDOJ 2010 水仙花数

简介: Problem Description 春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的: “水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3+3^3。

Problem Description
春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的:
“水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3+3^3。
现在要求输出所有在m和n范围内的水仙花数。

Input
输入数据有多组,每组占一行,包括两个整数m和n(100<=m<=n<=999)。

Output
对于每个测试实例,要求输出所有在给定范围内的水仙花数,就是说,输出的水仙花数必须大于等于m,并且小于等于n,如果有多个,则要求从小到大排列在一行内输出,之间用一个空格隔开;
如果给定的范围内不存在水仙花数,则输出no;
每个测试实例的输出占一行。

Sample Input
100 120
300 380

Sample Output
no
370 371

水题

import java.util.*;
class Main{
    public static void main(String args[]){
         Scanner sc    = new Scanner(System.in);
         while(sc.hasNext()){
             int n = sc.nextInt();
             int m = sc.nextInt();
             if(n>m){
                 n=n+m;
                 m=n-m;
                 n=n-m;
             }
             boolean isFirst = true;
             for(int i=n;i<=m;i++){
                 if(shui(i)){
                     if(isFirst){
                         isFirst = false;
                        System.out.print(i);
                     }else{
                     System.out.print(" "+i);
                     }
                 }
             }
             if(isFirst)
                System.out.print("no");
              System.out.println();
         }
    }
    public static boolean shui(int d ){
        int a=d/100;
        int b=(d/10)%10;
        int c=d%10;
        /*System.out.println(a+","+b+","+c);*/
        if((a*a*a+b*b*b+c*c*c)==d)
            return true;
        return false;
    }
}
目录
相关文章
|
4月前
水仙花数
水仙花数。
115 7
|
8月前
|
C++
水仙花数.
这是一个关于求解水仙花数的C++代码片段。水仙花数是指3位数,其各位数字立方和等于该数本身,如153。代码通过循环遍历100到999,拆分每位数字并计算立方和,如果满足条件则输出该数。解题关键在于对三位数的个位、十位、百位进行拆分和立方运算。
86 0
求1000以内所有的水仙花数
求1000以内所有的水仙花数
|
算法
求水仙花数
求水仙花数
87 0
找出水仙花数
找出水仙花数
87 0
7-150 水仙花数
7-150 水仙花数
55 0
7-107 找出三位水仙花数
7-107 找出三位水仙花数
109 0
每日一题——“水仙花数”
哈喽大家好,我是保护小周ღ,本期为大家带来的是求“水仙花数”,此水仙花,非彼水仙花,一起来看看把~
133 0
PTA 7-80 水仙花数 (20分)
PTA 7-80 水仙花数 (20分)
376 0