码迷,mamicode.com
首页 > 其他好文 > 详细

A题之拼音转数字

时间:2015-08-14 10:02:23      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:acm   java   拼音转数字   华为笔试   

输入是一个只包含拼音的字符串,请输出对应的数字序列。转换关系如下:
描述: 拼音 yi er san si wu liu qi ba jiu
      阿拉伯数字 1 2 3 4 5 6 7 8 9
输入字符只包含小写字母,所有字符都可以正好匹配

运行时间限制:无限制
内存限制: 无限制
输入: 一行字符串,长度小于1000
输出: 一行字符(数字)串
样例输入: yiersansi
样例输出: 1234

思路:
1)<拼音,数字>作为键值对,保存在hashmap中
2)字符串循环,从hashmap中取出响应的数字

Java解法:
import java.util.HashMap;
import java.util.Scanner;

public class Main
{
     public static void main(String[] args)
     {
  Scanner cin=new Scanner(System.in);
  HashMap<String, Integer> hashMap=new HashMap<>();
  hashMap.put("yi", 1);
  hashMap.put("er", 2);
  hashMap.put("san", 3);
  hashMap.put("si", 4);
  hashMap.put("wu", 5);
  hashMap.put("liu", 6);
  hashMap.put("qi", 7);
  hashMap.put("ba", 8);
  hashMap.put("jiu", 9);
 
  while(cin.hasNext())
  {
   func(hashMap, cin.next());
   break;
  }
 }
 
 public static void func(HashMap<String, Integer> hashMap, String str)
 {
  int k1=0;
  int k2=2;
  //System.out.println(hashMap.get("111"));
  while(k2<=str.length())
  {
   if (hashMap.get(str.subSequence(k1, k2))!=null)
   {
    System.out.print(hashMap.get(str.subSequence(k1, k2)));
   }
   else {
    k2++;
    if (hashMap.get(str.subSequence(k1, k2))!=null)
    {
     System.out.print(hashMap.get(str.subSequence(k1, k2)));
    }
   }
   k1=k2;
   k2+=2;
  }
 }
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

A题之拼音转数字

标签:acm   java   拼音转数字   华为笔试   

原文地址:http://blog.csdn.net/lyric_315/article/details/47656589

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!