华为机试题---已知:yi er san si wu liu qi ba jiu 分别对应123456789

该博客介绍了一道华为机试题,内容涉及将特定字符串如'yi er san si wu liu qi ba jiu'转换为对应的数字。博主分析了解题思路,包括存储对应关系、分割输入字符串和匹配子字符串的方法,探讨了多种实现策略,如使用数组、列表或映射数据结构,以及正则表达式的应用。
摘要由CSDN通过智能技术生成

一、题目

* 功能描述:已知:yi er san si wu liu qi ba jiu 分别对应123456789, 对一段只含有这几种字符串的字符串进行转换,如:
 * 输入:yiersansan 输出:1233

二、思路分析

1. 思路分析
 * 首先要解决三个问题:
 * 第一、怎么存储常量字符串和数据对应关系。
 * 第二、如何分割对于输入的字符串,获得出有数字对应的子字符串。
 * 第三、 如何对子字符串进行匹配,寻找下一个。

三、算法分析


 *  第一、怎么存储常量字符串和数据对应关系。
 * 由于看到是字符串和数字是一一对应,并且都没有重复,故可以想到以下三种存储方式
 * 1> 用一维数组,以位置 + 1为数字,内容为字符串。例如String [] arr = {"yi"....}; 然后遍历输入字符串,可以匹配到yi,则为return index + 1;
 * 因为数组是从零开始的。
 * 2> 用list存储,可以用到list.indexof(object o) 方法,并且可以用contains(object o)进行判断是否存在。
 * 3> 用map存储,可以吧map定义为hash

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值