HDU2097 Sky数

来源:互联网 发布:私人影院点播软件 编辑:程序博客网 时间:2024/05/01 17:56
</pre><h1 style="COLOR: #1a5cc8">Sky数</h1><span size="+0" style=""><strong><span style="font-family: Arial; color: green; font-size: 12px;">Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 20258    Accepted Submission(s): 11512</span></strong></span><div class="panel_title" align="left">Problem Description</div><div class="panel_content">Sky从小喜欢奇特的东西,而且天生对数字特别敏感,一次偶然的机会,他发现了一个有趣的四位数2992,这个数,它的十进制数表示,其四位数字之和为2+9+9+2=22,它的十六进制数BB0,其四位数字之和也为22,同时它的十二进制数表示1894,其四位数字之和也为22,啊哈,真是巧啊。Sky非常喜欢这种四位数,由于他的发现,所以这里我们命名其为Sky数。但是要判断这样的数还是有点麻烦啊,那么现在请你帮忙来判断任何一个十进制的四位数,是不是Sky数吧。</div><div class="panel_bottom"> </div><div class="panel_title" align="left">Input</div><div class="panel_content">输入含有一些四位正整数,如果为0,则输入结束。</div><div class="panel_bottom"> </div><div class="panel_title" align="left">Output</div><div class="panel_content">若n为Sky数,则输出“#n is a Sky Number.”,否则输出“#n is not a Sky Number.”。每个结果占一行。注意:#n表示所读入的n值。</div><div class="panel_bottom"> </div><div class="panel_title" align="left">Sample Input</div><div class="panel_content"><pre><div style="FONT-FAMILY: Courier New,Courier,monospace">299212340</div>
 

Sample Output
2992 is a Sky Number.1234 is not a Sky Number.
 

Source
2007省赛集训队练习赛(2)  

原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=2097


AC代码:
import java.util.*;class Main{    public static void main(String args[]){        Scanner sc=new Scanner(System.in);        while(sc.hasNext()){              int n=sc.nextInt();              if(n==0)  break;              if(fun(10,n)==fun(12,n)&&fun(10,n)==fun(16,n)){                 System.out.println(n+" is a Sky Number.");              }else{               System.out.println(n+" is not a Sky Number.");            }        }    }    public static int fun(int m,int n){        int sum=0;        while(n>0){           sum+=n%m;           n=n/m;        }        return sum;    }}



                                             
0 0
原创粉丝点击