[Leetcode] 500. Keyboard Row 解题报告

本文介绍了一种算法,用于从给定的单词列表中筛选出仅使用美式键盘一行字母即可拼写的单词。通过构建一个长度为26的向量模拟哈希表,将每个小写字母映射到其对应的键盘行编号,进而判断单词是否符合要求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目

Given a List of words, return the words that can be typed using letters of alphabet on only one row's of American keyboard like the image below.


American keyboard


Example 1:

Input: ["Hello", "Alaska", "Dad", "Peace"]
Output: ["Alaska", "Dad"]

Note:

  1. You may use one character in the keyboard more than once.
  2. You may assume the input string will only contain letters of alphabet.

思路

我们可以用一个长度为26的向量来模拟哈希表:每个小写字母对应其在美式键盘上的行编号。然后对于每个单词,统计每个字符出现的行编号集合。如果最终行编号集合的大小为1,那么就符合条件,加入结果集中。

代码

class Solution {
public:
    vector<string> findWords(vector<string>& words) {
        set<int> lines;
        vector<string> ret;
        vector<int> hash = {2, 3, 3, 2, 1, 2, 2, 2, 1, 2, 2, 2, 3, 3, 1, 1, 1, 1, 2, 1, 1, 3, 1, 3, 1, 3};
        for (auto s : words) {
            lines.clear();
            for (auto c : s) {
                lines.insert(hash[tolower(c) - 'a']);
            }
            if (lines.size() == 1) {
                ret.push_back(s);
            }
        }
        return ret;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值