567. 字符串的排列(c++)滑动窗口

简介: 567. 字符串的排列(c++)滑动窗口

给你两个字符串 s1 和 s2 ,写一个函数来判断 s2 是否包含 s1 的排列。如果是,返回 true ;否则,返回 false 。


换句话说,s1 的排列之一是 s2 的 子串 。


示例 1:


输入:s1 = "ab" s2 = "eidbaooo"

输出:true

解释:s2 包含 s1 的排列之一 ("ba").

示例 2:


输入:s1= "ab" s2 = "eidboaoo"

输出:false

提示:

  • 1 <= s1.length, s2.length <= 104
  • s1s2 仅包含小写字母

初始化哈希表:两个向量 hashmap1 和 hashmap2 被初始化为大小为26,所有元素的初始值都为0。这些向量用于计算字符串 s1 和 s2 中每个字符的出现次数


vector<int> hashmap1(26, 0);

vector<int> hashmap2(26, 0);

检查长度:比较 s1 和 s2 的长度。如果 s1 的长度大于 s2 的长度,则函数返回 false。这是因为如果 s1 比 s2 长,那么 s1 不能是 s2 的排列


int n = s1.size();

int m = s2.size();

if (n > m) {

   return false;

}

计算字符出现次数:遍历字符串 s1 和 s2,使用哈希表 hashmap1 和 hashmap2 计算每个字符的出现次数。


for (int i = 0; i < n; ++i) {

   hashmap1[s1[i] - 'a']++;

   hashmap2[s2[i] - 'a']++;

}


比较哈希表:在计算出现次数后,代码比较了两个哈希表。如果它们相等,那么意味着 s1 是 s2 的排列,因此函数返回 true。


if (hashmap1 == hashmap2) {

   return true;

}


滑动窗口技术:如果字符串的长度相等但哈希表不相等,则使用滑动窗口技术来检查排列。窗口大小为 n,即 s1 的长度。代码遍历 s2,更新窗口的哈希表并将其与 hashmap1 进行比较。如果它们在任何时候相等,函数返回 true


for (int i = n; i < m; ++i) {

   hashmap2[s2[i] - 'a']++;

   hashmap2[s2[i - n] - 'a']--;


   if (hashmap1 == hashmap2) {

       return true;

   }

}


具体代码如下:

class Solution {
public:
    bool checkInclusion(string s1, string s2) {
    vector<int> hashmap1 (26, 0);
    vector<int> hashmap2 (26, 0);
    int n = s1.size();
    int m = s2.size();
    if(n>m){
        return false;
    }
    for (int i = 0; i < n; ++i) {
        hashmap1[s1[i]-'a']++;
        hashmap2[s2[i]-'a']++;
    }
    if (hashmap1 == hashmap2) {
        return true;
    }
    for (int i = n; i < m; ++i) {
        hashmap2[s2[i]-'a']++;
        hashmap2[s2[i - n]-'a']--;
        if (hashmap1 == hashmap2) {
            return true;
        }
    }
    return false;}
};
相关文章
|
1月前
|
算法 C++
2730. 找到最长的半重复子字符串(c++,滑动窗口)
2730. 找到最长的半重复子字符串(c++,滑动窗口)
|
1月前
|
编译器 C++
【C++】string类的使用④(字符串操作String operations )
这篇博客探讨了C++ STL中`std::string`的几个关键操作,如`c_str()`和`data()`,它们分别返回指向字符串的const char*指针,前者保证以&#39;\0&#39;结尾,后者不保证。`get_allocator()`返回内存分配器,通常不直接使用。`copy()`函数用于将字符串部分复制到字符数组,不添加&#39;\0&#39;。`find()`和`rfind()`用于向前和向后搜索子串或字符。`npos`是string类中的一个常量,表示找不到匹配项时的返回值。博客通过实例展示了这些函数的用法。
|
2月前
|
C++ 容器
C++字符串string容器(构造、赋值、拼接、查找、替换、比较、存取、插入、删除、子串)
C++字符串string容器(构造、赋值、拼接、查找、替换、比较、存取、插入、删除、子串)
36 1
|
1月前
|
vr&ar C++
1695. 删除子数组的最大得分(C++,滑动窗口)
1695. 删除子数组的最大得分(C++,滑动窗口)
|
2月前
|
编译器 C++
【C++进阶】深入STL之string:模拟实现走进C++字符串的世界
【C++进阶】深入STL之string:模拟实现走进C++字符串的世界
28 1
|
2月前
|
存储 算法 Cloud Native
C++ bcrypt算法 字符串加密,亲测有效
C++ bcrypt算法 字符串加密,亲测有效
|
3月前
|
C++ 索引
C++中字符串常用操作
C++中字符串常用操作
19 2
|
2月前
|
C++ 容器
【C++语言】String 类关键函数实现,手搓一个简单字符串类!
【C++语言】String 类关键函数实现,手搓一个简单字符串类!
|
2月前
|
C++ 安全
高效遍历:C++中分隔字符串单词的3种方法详解与实例
拷贝并交换(Copy-and-Swap)是C++中实现赋值操作符和异常安全拷贝构造函数的技巧。它涉及创建临时对象,使用拷贝构造函数,然后交换数据以确保安全。C++11之前的策略在此后及C++11引入的移动语义和右值引用下仍有效,但后者提供了更高效的实现方式。
|
5天前
|
C++ 容器
C++中自定义结构体或类作为关联容器的键
C++中自定义结构体或类作为关联容器的键
12 0