力扣(LeetCode)500. 键盘行

Posted lick

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了力扣(LeetCode)500. 键盘行相关的知识,希望对你有一定的参考价值。

给定一个单词列表,只返回可以使用在键盘同一行的字母打印出来的单词。键盘如下图所示。

示例:

输入: ["Hello", "Alaska", "Dad", "Peace"]
输出: ["Alaska", "Dad"]

注意:

你可以重复使用键盘上同一字符。
你可以假设输入的字符串将只包含字母。

思路 获取每个单词的每个字母,进行所在行的判定,如果该单词所有字母都在同一行,则添加,否则不添加

java版

class Solution {
    public String[] findWords(String[] words) {
        List<String> list = new LinkedList<>();
        String q = "qwertyuiopQWERTYUIOP";
        String a = "asdfghjklASDFGHJKL";
        String z = "zxcvbnmZXCVBNM";
        int i,j;
        for(i=0;i<words.length;i++) {
            int len = words[i].length();
            int one=0,two=0,three=0;//单词字母所在的行数
            for(j=0;j<len;j++) {
                String s = words[i].substring(j,j+1);
                if(q.contains(s)) {
                    one++;
                }else if(a.contains(s)) {
                    two++;
                }else if(z.contains(s)) {
                    three++;
                }
            }
            // 如果单词每个字母都在同一行,则添加进list
            if(one == len || two == len || three == len) {
                list.add(words[i]);
            }
        }
        
        return list.toArray(new String[list.size()]);
        
    }
}

运行结果

以上是关于力扣(LeetCode)500. 键盘行的主要内容,如果未能解决你的问题,请参考以下文章

leetcode500. 键盘行

leetcode打卡——500. 键盘行

LeetCode 500 键盘行[遍历] HERODING的LeetCode之路

精选力扣500题 第25题 LeetCode 54. 螺旋矩阵c++ / java 详细题解

python leetcode练习(500.键盘行)

Leetcode——500. 键盘行(Java)