Leetcode PHP题解--D25 500. Keyboard Row

500. Keyboard Row

题目链接

500. Keyboard Row

题目分析

给定一个字符串数组,返回那些所出现的字母在QWERTY键盘中同一行的字符串。

例如,单词hello中,字母hl在键盘的第二行(或者中间那一行),剩余字母eo在第一行。故排除之。
再如,Dalas中,所有字母都在中间那一行,则返回它。

思路

我的思路是,把键盘中每一行出现的字母存进3个数组中(因为有3行),将每个字符串分割成数组,判断该数组与每一行字母数组是否有差集。如果分散在不同行,则必定会在与某一行有差。用array_filter函数过滤这些有差的字符串即可。

最终代码

<?php
class Solution {
    function findWords($words) {
        return array_filter($words, function($val){
            $val = array_unique(str_split(strtolower($val)));
            $q = ['q','w','e','r','t','y','u','i','o','p'];
            $a = ['a','s','d','f','g','h','j','k','l'];
            $z = ['z','x','c','v','b','n','m'];

            return !(array_diff($val,$q) && array_diff($val,$a)&&
                array_diff($val,$z));
        });
    }
}

若觉得本文章对你有用,欢迎用爱发电资助。

skys215 has written 95 articles

没有bug的代码是有bug的代码。

积分:4757 等级:P8 职业:PHP工程师 城市:深圳

0 条回复

登录后才能进行评论,立即登录?