博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
A题之拼音转数字
阅读量:4450 次
发布时间:2019-06-07

本文共 1194 字,大约阅读时间需要 3 分钟。

输入是一个仅仅包括拼音的字符串,请输出相应的数字序列。转换关系例如以下:
描写叙述: 拼音 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;
  }
 }
}

转载于:https://www.cnblogs.com/jzssuanfa/p/6985358.html

你可能感兴趣的文章
在WPF中自定义控件(3) CustomControl (下)
查看>>
C# 验证识别基类
查看>>
用bat 删除当前文件夹下的某类文件
查看>>
先序遍历和后序遍历构建二叉树
查看>>
linux xorddos样本分析1
查看>>
【数论】-素数问题整理
查看>>
提高你的Java代码质量吧:正确使用String、StringBuffer、StringBuilder
查看>>
[happyctf]部分writeup
查看>>
HDU 1195 Open the Lock(BFS)
查看>>
Struts2的crud
查看>>
java上传文件
查看>>
大学生对技术网站需求的调查问卷结果分析
查看>>
测试一
查看>>
vertx的HttpServer模块
查看>>
as3事件流机制彻底理解
查看>>
Selenium webdriver操作日历控件
查看>>
Pascal程序练习-与7无关的数
查看>>
Linux:cut命令...未完待续
查看>>
微信小程序从零开始开发步骤(一)搭建开发环境
查看>>
SQL*Net more data to client
查看>>