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


数数
时间限制: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;
	}
	
	
}

转载于:https://my.oschina.net/willyliu/blog/131795

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值