500. Keyboard Row

本文介绍了一个算法问题,即如何找出可以使用美国键盘某一行字母组成的单词。通过将键盘上每行的字符存储到对应的集合中,并遍历输入的单词列表进行匹配,实现了一种高效的解决方案。

摘要生成于 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.
分析:vector<string>&word 给出N个字符串   将键盘上的每一行字符存储到对应的vector中, 然后循环 word中的每一个string
class Solution {
public:
    vector<string> findWords(vector<string>& words) {
        unordered_set<char> set1 = {'Q','q','W','w','E','e','R','r','T','t','Y','y','U','u','I','i','O','o','P','p'};  
        unordered_set<char> set2 = {'S','s','D','d','F','f','G','g','H','h','J','j','K','k','L','l','a','A'};  
        unordered_set<char> set3 = {'Z','z','X','x','C','c','V','v','B','b','N','n','M','m'};  
        vector<unordered_set<char>> sets = {set1, set2, set3}; 
        vector<string> out;  
        for(int i =0;i<words.size();i++){
            int index =0;
            if(set1.find(words[i][0]) !=set1.end()) index =0;
            else if(set2.find(words[i][0]) !=set2.end()) index =1;
            else if(set3.find(words[i][0]) !=set3.end()) index =2;
            unordered_set<char> tmp =sets[index];
            int flag= 0;
            for(char c:words[i]){
                if(tmp.find(c) !=tmp.end()) continue;
                else {
                    flag =1;
                    break;
                }
            }
            if(!flag) out.push_back(words[i]);
        }
        return out;
    }
};


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值