java 键盘输入单词 与单词表匹配_数据结构算法(手机键盘输入数字返回匹配单词)...

文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢!

题目

在老式手机上,用户通过数字键盘输入,手机将提供与这些数字相匹配的单词列表。每个数字映射到0至4个字母。给定一个数字序列,实现一个算法来返回匹配单词的列表。你会得到一张含有有效单词的列表。映射如下图所示:

6ba3c62f62d8e839223d3b80288e8ca1.png

示例 1:

输入: num = "8733", words = ["tree", "used"]

输出: ["tree", "used"]

示例 2:

输入: num = "2", words = ["a", "b", "c", "d"]

输出: ["a", "b", "c"]

提示:

num.length <= 1000

words.length <= 500

words[i].length == num.length

num中不会出现 0, 1 这两个数字

Java

思路

将26个字母按顺序将对应的数字存入数组,再比对输入的数字是否符合

代码

class Solution {

public List getValidT9Words(String num, String[] words) {

List res = new ArrayList<>();

char[] map = {'2','2','2','3','3','3','4','4','4','5','5','5','6','6','6','7','7','7','7','8','8','8','9','9','9','9'};

for(String word : words){

int index = 0;

boolean flag = true;

for(char c : word.toCharArray()){

char n = map[c-'a'];

if(n != num.charAt(index++)){

flag = false;

break;

}

}

if(flag){

res.add(word);

}

}

return res;

}

}

感谢

本文地址:https://blog.csdn.net/qq_45163122/article/details/107874954

希望与广大网友互动??

点此进行留言吧!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值