您的位置:首页 > 其它

NYOJ-ACM- 数数

2017-04-27 20:25 246 查看


数数

时间限制:3000 ms  |  内存限制:65535 KB
难度:2

描述

我们平时数数都是喜欢从左向右数的,但是我们的小白同学最近听说德国人数数和我们有些不同,他们正好和我们相反,是从右向左数的。因此当他看到123时会说“321”。

现在有一位德国来的教授在郑州大学进行关于ACM的讲座。现在他聘请你来担任他的助理,他给你一些资料让你找到这些资料在书中的页数。现在你已经找到了对应的页码,要用英文把页码告诉他。

为了简化我们的问题,你只需要返回单词的大写的首字母。(数字0读成字母O)

注意:每个数字式单独读取的,因此不会出现11读成double one的情况。

输入输入分两部分:

第一部分:一个整数T(1<=T<=1000)

第二部分:一共T行,每行为一个数字。每个数的长度不超过10位。
输出每组输出单独占一行,输出对应的返回给德国教授的页码缩写。
样例输入
2
12
1234


样例输出
TO
FTTO


思路:

这道题大家肯定会输入int型,但是题目并没有说输入几位数,只是说了输入一个不超过10位的数字。用int就有点繁琐。所以用String型的。因为String中有length这个函数。可以知道输入数字的位数,也能用charAt()将数字分开。之后我是用了一个二维数组char来存放结果数据。最后判断输出。大家可以参考我的代码,不懂的可以留言。

代码:

import java.util.Scanner;
import java.util.Stack;

public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc = new Scanner(System.in);
int a = sc.nextInt();
String[] s = new String[a];//数据的存储
char[][] aa = new char[a][10];//结果数组
for(int i=0;i<a;i++){
s[i] = sc.next();
for(int j=0;j<s[i].length();j++){
char[] ss = new char[s[i].length()];
ss[j] = s[i].charAt(j);
if(ss[j] == '0'){//判断
aa[i][j] = 'O';
}else if(ss[j] == '1'){
aa[i][j] ='O';
}else if(ss[j] == '2'){
aa[i][j] = 'T';
}else if(ss[j] == '3'){
aa[i][j] = 'T';
}else if(ss[j] == '4'){
aa[i][j] = 'F';
}else if(ss[j] == '5'){
aa[i][j] = 'F';
}else if(ss[j] == '6'){
aa[i][j] = 'S';
}else if(ss[j] == '7'){
aa[i][j] = 'S';
}else if(ss[j] == '8'){
aa[i][j] = 'E';
}else if(ss[j] == '9'){
aa[i][j] = 'N';
}
}

}
for(int i=0;i<a;i++){
for(int j=s[i].length()-1;j>=0;j--){//判断输出
if(j!=0){
System.out.print(aa[i][j]);
}else if(j == 0){
System.out.println(aa[i][j]);
}

}

}

}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  NYOJ-ACM- 数数