拼音查找,设计一种机制能够从给定的拼音定位到合适的人名

package cn.itcast.map;
/**
 * 我们在使用手机通信录的时候,都希望能快速定位某人。

        比较流行的做法是输入拼音首字母。

        假设某个列表中存储着许多联系人的名字。请设计一种机制能够从给定的拼音定位到合适的人名,如有多个人匹配,则定位多个人。

        能支持模糊音吗?

        提示: 汉字的GBK编码就是按照拼音顺序的。只要抽出每个声母的开始汉字就可以了。
 */
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Scanner;
import java.util.Set;

public class Pinyin {

public static Set<String> inputStr(String str) {

// key是搜所到的结果,value是输入的搜索的关键字
Map<String, String> map = new HashMap<String, String>();
map.put("要", "y");
map.put("也", "y");
map.put("有", "y");
map.put("药", "y");
map.put("一", "y");
map.put("姚飞", "yf");
map.put("语法", "yf");
map.put("月份", "yf");
map.put("运费", "yf");
map.put("一份", "yf");
map.put("缘分", "yf");

final List<Map.Entry<String, String>> info = new ArrayList<Map.Entry<String, String>>(
map.entrySet());

Set<String> set = new HashSet<String>();
for (int i = 0; i < info.size(); i++) {
if (str.equals(info.get(i).getValue())) {

set.add(info.get(i).getKey());
}
}

return set;
}

public static void main(String[] args) {

Map<String, String> map = new HashMap<String, String>();

while (true) {
System.out.println("请输入’y‘或者’yf‘搜:");

Scanner scan1 = new Scanner(System.in);
String str1 = scan1.next();
Set<String> set1 = inputStr(str1);

Iterator<String> iter = set1.iterator();
while (iter.hasNext()) {

String str2 = iter.next();
System.out.println(str2);
}
}
}

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值