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;
    }
}
目录
相关文章
求1000以内所有的水仙花数
求1000以内所有的水仙花数
|
程序员
【牛客网】HJ99 自守数、OR86 返回小于 N 的质数个数
目录 HJ99 自守数 OR86 返回小于 N 的质数个数
83 0
|
算法
求水仙花数
求水仙花数
78 0
找出水仙花数
找出水仙花数
83 0
7-150 水仙花数
7-150 水仙花数
48 0
PTA 7-80 水仙花数 (20分)
PTA 7-80 水仙花数 (20分)
366 0
HDOJ 2010 水仙花数
HDOJ 2010 水仙花数
119 0
HDOJ(HDU) 2521 反素数(因子个数~)
HDOJ(HDU) 2521 反素数(因子个数~)
109 0
|
Java
HDOJ 1018 Big Number(大数位数公式)
HDOJ 1018 Big Number(大数位数公式)
113 0
HDOJ/HDU 2352 Verdis Quo(罗马数字与10进制数的转换)
HDOJ/HDU 2352 Verdis Quo(罗马数字与10进制数的转换)
178 0