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));
        });
    }
}

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

转载于:https://my.oschina.net/u/2246923/blog/3032750

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值