给定两个字符串 **s1** 和 **s2**,写一个函数来判断 **s2** 是否包含 **s1** 的排列。
换句话说,第一个字符串的排列之一是第二个字符串的子串。
滑动窗口,s2包含s1的排列当且仅当s2存在一个子串,这个子串与s1对应字母个数相同。可以用大小为26的数组记录s1各个字母的个数,s1的话可以边更新到当前位置pos的各个字母的个数,也可以用前缀和。复杂度26 * n。
```c++
class Solution {
public:
bool checkInclusion(string s1, string s2) {
int sum1[10005][26], sum2[26];
memset(sum1, 0, sizeof(sum1))
string tmp = s2;
s2 = s1;
s1 = tmp;
s1 = " " + s1;
for(int i = 1
{
for(int j = 0
sum1[i][s1[i] - 'a']++;
}
for(int i = 0
for(int i = 1
{
bool flag = 1;
for(int j = 0
{
if(sum2[j] != sum1[i + s2.size() - 1][j] - sum1[i - 1][j])
{
flag = 0;
break;
}
}
if(flag) return true;
}
return false;
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2020-02-10 Codeforces Round #618 (Div. 2)A. Non-zero
2020-02-10 Codeforces Round #618 (Div. 2)C. Anu Has a Function