【力扣·每日一题】748. 最短补全词(C++ 模拟)

简介: 【力扣·每日一题】748. 最短补全词(C++ 模拟)

linkk

题意:

20200401134307494.png

思路:

题目有几个关键点:


不区分大小写

补全词优先选最短的

同样短的选最靠前的

预处理出字符串l i c e n s e P l a t e中每个字母出现的次数(不区分大小写)

然后遍历给出的补全词集合,对于每个补全词统计每个字母出现的次数,看是否符合题目的要求,再选择最靠前的最短的作为答案。

代码:

class Solution {
public:
    string shortestCompletingWord(string licensePlate, vector<string>& words) {
        int a[27],b[27];
        memset(a,0,sizeof a);
        for(int i=0;licensePlate[i];i++){
            char t=licensePlate[i];
            if(t>='A'&&t<='Z') a[t-'A']++;
            else if(t>='a'&&t<='z') a[t-'a']++;
        }
        string ans="9999999999999999999999999999999999999999999999999999999";
        for(string s:words){
            memset(b,0,sizeof b);
            for(int i=0;s[i];i++) b[s[i]-'a']++;
            bool flag=1;
            for(int j=0;j<26;j++)
                if(a[j]!=0&&a[j]>b[j]){
                    flag=0;break;
                }
            if(flag){
                if(ans.size()>s.size())
                    ans=s;
            }
        }
        return ans;
    }
};
目录
相关文章
|
6月前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-2
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
6月前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-1
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
7月前
|
算法 C语言 容器
从C语言到C++_25(树的十道OJ题)力扣:606+102+107+236+426+105+106+144+94+145(下)
从C语言到C++_25(树的十道OJ题)力扣:606+102+107+236+426+105+106+144+94+145
68 7
|
7月前
|
存储 算法 C语言
从C语言到C++_39(C++笔试面试题)next_permutation刷力扣
从C语言到C++_39(C++笔试面试题)next_permutation刷力扣
67 5
|
7月前
|
存储 C语言 容器
从C语言到C++_26(set+map+multiset+multimap)力扣692+349+牛客_单词识别(下)
从C语言到C++_26(set+map+multiset+multimap)力扣692+349+牛客_单词识别
49 1
|
7月前
|
存储 C语言 容器
从C语言到C++_26(set+map+multiset+multimap)力扣692+349+牛客_单词识别(中)
从C语言到C++_26(set+map+multiset+multimap)力扣692+349+牛客_单词识别
49 1
|
7月前
|
存储 自然语言处理 C语言
从C语言到C++_26(set+map+multiset+multimap)力扣692+349+牛客_单词识别(上)
从C语言到C++_26(set+map+multiset+multimap)力扣692+349+牛客_单词识别
63 1
|
7月前
|
C语言
从C语言到C++_25(树的十道OJ题)力扣:606+102+107+236+426+105+106+144+94+145(中)
从C语言到C++_25(树的十道OJ题)力扣:606+102+107+236+426+105+106+144+94+145
59 1
|
19天前
|
存储 编译器 C语言
【c++丨STL】string类的使用
本文介绍了C++中`string`类的基本概念及其主要接口。`string`类在C++标准库中扮演着重要角色,它提供了比C语言中字符串处理函数更丰富、安全和便捷的功能。文章详细讲解了`string`类的构造函数、赋值运算符、容量管理接口、元素访问及遍历方法、字符串修改操作、字符串运算接口、常量成员和非成员函数等内容。通过实例演示了如何使用这些接口进行字符串的创建、修改、查找和比较等操作,帮助读者更好地理解和掌握`string`类的应用。
29 2
|
25天前
|
存储 编译器 C++
【c++】类和对象(下)(取地址运算符重载、深究构造函数、类型转换、static修饰成员、友元、内部类、匿名对象)
本文介绍了C++中类和对象的高级特性,包括取地址运算符重载、构造函数的初始化列表、类型转换、static修饰成员、友元、内部类及匿名对象等内容。文章详细解释了每个概念的使用方法和注意事项,帮助读者深入了解C++面向对象编程的核心机制。
59 5