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;}
};
相关文章
|
2月前
|
搜索推荐 编译器 C语言
【C++核心】特殊的元素集合-数组与字符串详解
这篇文章详细讲解了C++中数组和字符串的基本概念、操作和应用,包括一维数组、二维数组的定义和使用,以及C风格字符串和C++字符串类的对比。
78 4
|
1月前
|
缓存 网络协议 API
C/C++ StringToAddress(字符串转 boost::asio::ip::address)
通过上述步骤和示例代码,你可以轻松地在C++项目中实现从字符串到 `boost::asio::ip::address`的转换,从而充分利用Boost.Asio库进行网络编程。
50 0
|
1月前
|
编译器 C语言 C++
C/C++数字与字符串互相转换
C/C++数字与字符串互相转换
|
2月前
|
C++
HTML+JavaScript构建一个将C/C++定义的ANSI字符串转换为MASM32定义的DWUniCode字符串的工具
HTML+JavaScript构建一个将C/C++定义的ANSI字符串转换为MASM32定义的DWUniCode字符串的工具
|
2月前
|
存储 C++
C++(五)String 字符串类
本文档详细介绍了C++中的`string`类,包括定义、初始化、字符串比较及数值与字符串之间的转换方法。`string`类简化了字符串处理,提供了丰富的功能如字符串查找、比较、拼接和替换等。文档通过示例代码展示了如何使用这些功能,并介绍了如何将数值转换为字符串以及反之亦然的方法。此外,还展示了如何使用`string`数组存储和遍历多个字符串。
|
4月前
|
算法 C++
2730. 找到最长的半重复子字符串(c++,滑动窗口)
2730. 找到最长的半重复子字符串(c++,滑动窗口)
|
4月前
|
编译器 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类中的一个常量,表示找不到匹配项时的返回值。博客通过实例展示了这些函数的用法。
|
5月前
|
C++ 容器
C++字符串string容器(构造、赋值、拼接、查找、替换、比较、存取、插入、删除、子串)
C++字符串string容器(构造、赋值、拼接、查找、替换、比较、存取、插入、删除、子串)
|
4月前
|
vr&ar C++
1695. 删除子数组的最大得分(C++,滑动窗口)
1695. 删除子数组的最大得分(C++,滑动窗口)
|
4天前
|
存储 编译器 C++
【c++】类和对象(中)(构造函数、析构函数、拷贝构造、赋值重载)
本文深入探讨了C++类的默认成员函数,包括构造函数、析构函数、拷贝构造函数和赋值重载。构造函数用于对象的初始化,析构函数用于对象销毁时的资源清理,拷贝构造函数用于对象的拷贝,赋值重载用于已存在对象的赋值。文章详细介绍了每个函数的特点、使用方法及注意事项,并提供了代码示例。这些默认成员函数确保了资源的正确管理和对象状态的维护。
21 4