定长滑动窗口-----金丹篇

今天是不同的类型,话说定长滑动窗口中,经常会出现这样一类题目,给你两个串,一个串的排列可能是另一个串的子串,让你求出子串开始的位置,或者证明是否存在这样的子串。

一.热身阶段

 力扣567.字符串的排列

https://leetcode.cn/problems/permutation-in-string/description/https://leetcode.cn/problems/permutation-in-string/description/

题目:

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

换句话说,s1 的排列之一是 s2 的 子串 。(s1和s2只包含小写字母)

示例:

输入:s1 = "ab" s2 = "eidbaooo"
输出:true
解释:s2 包含 s1 的排列之一 ("ba").

这时候就有兄弟会问了,这咋用模板呢,s1的排列这么多个,我难道要一个一个列出来吗,主播有什么简单的方法吗?有的兄弟有的,我们可以化整为零嘛,s1字符串说到底是由k(s1的大小)个字符组成的,那么我们就可以用一个数组维护s1的字符以及对应的数量,这一样一来我们就将问题转换为窗口中字符以及对应的数量是否和s1相同即可。细节上,我们将s1存在的字符在数组中+1,入窗时,将字符在数组中-1,最终看数组中的元

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

极道万岁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值