发短信_NYOJ_643
2014-03-05 15:55
239 查看
发短信
时间限制:1000 ms | 内存限制:65535 KB难度:3
描述
下图是手机常用的九键英文输入法界面,如果要输入字母'A',我们只
需要按一次数字键2,按键顺序记为2;如果要输入字母'B'的话,我们需要连续按两次数字键2,按键顺序记为22;同理:字母'C’需要连续按3次数字键2,按键顺序记为222。通过这种方法,我们用手机10多个键就能输入26个英文字母。
现在你的任务是统计一段英文用手机输入的按键顺序,同样,你也要能把按键顺序翻译成相应的英文内容。
为了使问题简化,我们假设内容只有大写英文字母和空格。
![](http://acm.nyist.net/JudgeOnline/admin/kind/attached/20121214223105_61561.png)
输入有多组测试数据
每组测试数据占一行,有两种情况:
(1)短信内容(只含有若干个空格和大写字母,不超过1000个字符)
(2)短信按键顺序(只含有若干空格和数字,其中第一个肯定是数字,不超过1000个字符)
输出对于每组测试数据:
如果是短信内容,输出每个字母的按键顺序,每个字母的按键顺序用空格隔开
如果是按键顺序,输出它代表的内容
样例输入
I LOVE YOU HELLO WORLD 444 0 555 666 888 33 0 999 666 88 44 33 555 555 666 0 9 666 777 555 3
样例输出
444 0 555 666 888 33 0 999 666 88 44 33 555 555 666 0 9 666 777 555 3 I LOVE YOU HELLO WORLD
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.HashMap;
import java.util.Map;
public class Main{
private static Map<String,String> map=null;
public static void main(String[] args) throws Exception {
BufferedReader bf=new BufferedReader(new InputStreamReader(System.in));
Init();
while(true){
String str=bf.readLine();
if(str==null||str.equals(""))
break;
boolean ok=false;
for(int i=0;i<str.length();i++){
char c=str.charAt(i);
if(c>='A'&&c<='Z'&&c!=' '){
ok=true;
break;
}else if(c>='0'&&c<='9'&&c!=' '){
break;
}
}
if(ok){
System.out.print(map.get(str.charAt(0)+""));
for(int i=1;i<str.length();i++){
System.out.print(" "+map.get(str.charAt(i)+""));
}
System.out.println();
}
else{
String s[]=str.split(" ");
for(int i=0;i<s.length;i++){
if(s[i]!=null){
System.out.print(map.get(s[i]));
}
}
System.out.println();
}
}
}
private static void Init() {
map=new HashMap<String, String>();
map.put("A", "2");
map.put("B", "22");
map.put("C", "222");
map.put("D", "3");
map.put("E", "33");
map.put("F", "333");
map.put("G", "4");
map.put("H", "44");
map.put("I", "444");
map.put("J", "5");
map.put("K", "55");
map.put("L", "555");
map.put("M", "6");
map.put("N", "66");
map.put("O", "666");
map.put("P", "7");
map.put("Q", "77");
map.put("R", "777");
map.put("S", "7777");
map.put("T", "8");
map.put("U", "88");
map.put("V", "888");
map.put("W", "9");
map.put("X", "99");
map.put("Y", "999");
map.put("Z", "9999");
map.put(" ", "0");
map.put("2","A");
map.put("22","B");
map.put("222","C");
map.put("3","D" );
map.put("33","E");
map.put("333","F");
map.put("4","G");
map.put("44","H");
map.put("444","I");
map.put("5", "J");
map.put("55", "K");
map.put("555", "L");
map.put("6", "M");
map.put("66", "N");
map.put("666", "O");
map.put("7", "P");
map.put("77", "Q");
map.put("777", "R");
map.put("7777", "S");
map.put("8", "T");
map.put("88", "U");
map.put("888", "V");
map.put("9", "W");
map.put("99", "X");
map.put("999", "Y");
map.put("9999", "Z");
map.put("0", " ");
}
}
相关文章推荐
- Python中map()函数浅析
- Android使用Google Map浅谈
- jquery与google map api结合使用 控件,监听器
- jquery遍历数组与筛选数组的方法
- Android Map新用法:MapFragment应用介绍
- js Map List 遍历使用示例
- velocity显示List与Map的方法详细解析
- Google Map Api和GOOGLE Search Api整合实现代码
- 关于STL中的map容器的一些总结
- vector,map,list,queue的区别详细解析
- 浅析stl序列容器(map和set)的仿函数排序
- Java中List与Map初始化的一些写法分享
- Java用for循环Map详细解析
- 5个数组Array方法: indexOf、filter、forEach、map、reduce使用实例
- JAVA Map架构和API介绍
- list,set,map,数组之间的相互转换详细解析
- java map遍历的四种方法总结
- 浅析Java中Map与HashMap,Hashtable,HashSet的区别
- HAZELCAST 客户端命令 可用于简单调试
- JDK API阅读体会 2-哈希还是哈希