数数
时间限制:3000 ms | 内存限制:65535 KB
难度:2
描述
我们平时数数都是喜欢从左向右数的,但是我们的小白同学最近听说德国人数数和我们有些不同,他们正好和我们相反,是从右向左数的。因此当他看到123时会说“321”。
现在有一位德国来的教授在郑州大学进行关于ACM的讲座。现在他聘请你来担任他的助理,他给你一些资料让你找到这些资料在书中的页数。现在你已经找到了对应的页码,要用英文把页码告诉他。
为了简化我们的问题,你只需要返回单词的大写的首字母。(数字0读成字母O)
注意:每个数字式单独读取的,因此不会出现11读成double one的情况。
输入
输入分两部分:
第一部分:一个整数T(1<=T<=1000)
第二部分:一共T行,每行为一个数字。每个数的长度不超过10位。
第一部分:一个整数T(1<=T<=1000)
第二部分:一共T行,每行为一个数字。每个数的长度不超过10位。
输出
每组输出单独占一行,输出对应的返回给德国教授的页码缩写。
样例输入
2
12
1234
样例输出
TO
FTTO
import java.util.Scanner;
/**
* 百度之星技术社区 [实训] 编程课堂实训习题:语言入门--数数
* @author liuwei
* 2013-4-30下午08:14:21
* TODO
*/
public class Main3 {
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
while(scanner.hasNext()) {
/**
* 输入的组数
*/
int T=scanner.nextInt();
assert (T>=1) && (T<=1000);
for(int index=0;index<T;index++) {
int num=scanner.nextInt(),n=0;
assert String.valueOf(num).length()<=10;
int[] intNum=new int[10];
while(num/10!=0) {
intNum[n]=num%10;
num=num/10;
n++;
}
intNum[n]=num;
for (int i = 0; i <=n; i++) {
System.out.print(getChar(intNum[i]));
}
System.out.println();
}
}
}
/**
* Task将数字转换成指定的字符
* @param num
* @return
*/
public static String getChar(int num) {
String flag=null;
switch (num) {
case 0: flag= "Z"; break;
case 1: flag= "O"; break;
case 2: flag= "T"; break;
case 3: flag= "T"; break;
case 4: flag= "F"; break;
case 5: flag= "F"; break;
case 6: flag= "S"; break;
case 7: flag= "S"; break;
case 8: flag= "E"; break;
case 9: flag= "N"; break;
}
return flag;
}
}