Leetcode——500. 键盘行(Java)

题目描述

给你一个字符串数组 words ,只返回可以使用在 美式键盘 同一行的字母打印出来的单词。
美式键盘中:
第一行由字符 "qwertyuiop" 组成。
第二行由字符 "asdfghjkl" 组成。
第三行由字符 "zxcvbnm" 组成。

示例 1:
输入:words = ["Hello","Alaska","Dad","Peace"]
输出:["Alaska","Dad"]

示例 2:
输入:words = ["omk"]
输出:[]

示例 3:
输入:words = ["adsdf","sfd"]
输出:["adsdf","sfd"]

题目分析

返回能在键盘同一行打出的字母,这里首先想到的就是枚举每行的字母,然后遍历判断

结果官方题解给出了一个优雅的方式,将26个字母按照行号排好,每次就去取行号即可

正确代码

    public String[] findWords(String[] words) {
        ArrayList<String> list = new ArrayList<>();
        String rowIdx = "12210111011122000010020202"; // 将英文字母转成行序号
        for (String word : words) {
            boolean isValid = true;
            char idx = rowIdx.charAt(Character.toLowerCase(word.charAt(0)) - 'a');
            for (int i = 0; i < word.length(); i++) {
                if (rowIdx.charAt(Character.toLowerCase(word.charAt(i)) - 'a') != idx) {
                    isValid = false;
                    break;
                }
            }
            if (isValid) {
                list.add(word);
            }
        }
        String[] ans = new String[list.size()];
        for (int i = 0; i < list.size(); i++) {
            ans[i] = list.get(i);
        }
        return ans;
    }

总结

其实不知道枚举和本方法的速度如何如何,不过算法还是要追求优雅和完美的解法

如果文章存在问题或者有更好的题解,欢迎在评论区斧正和评论,各自努力,最高处见
上一篇:网关平台架构分享


下一篇:java 彩票游戏