百度之星技术社区 [实训] 编程课堂实训习题:语言入门--数数


数数
时间限制:3000 ms | 内存限制:65535 KB
难度:2
描述
我们平时数数都是喜欢从左向右数的,但是我们的小白同学最近听说德国人数数和我们有些不同,他们正好和我们相反,是从右向左数的。因此当他看到123时会说“321”。
现在有一位德国来的教授在郑州大学进行关于ACM的讲座。现在他聘请你来担任他的助理,他给你一些资料让你找到这些资料在书中的页数。现在你已经找到了对应的页码,要用英文把页码告诉他。
为了简化我们的问题,你只需要返回单词的大写的首字母。(数字0读成字母O)
注意:每个数字式单独读取的,因此不会出现11读成double one的情况。
输入
输入分两部分:
第一部分:一个整数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;
	}
	
	
}

你可能感兴趣的:(百度之星技术社区)