由于题目中说了字符串组成成分仅含小写字母,因此我们可以维护一个 vector<int> mCount(26) ,代表子串中26个英文字母的数量情况,并设置字符串 p 的字母分布情况为 vector<int> nCount(26) ,当窗口中每种字母的数量与字符串 p 中每种字母的数量相同时,则说明当前窗口为字符串 p 的异位词,这样就做到了通过对比两个数组来降低时间复杂度。
方法二:优化的滑动窗口
明白了上面的道理,我们可以进一步优化滑动窗口,我们可以不再分别统计滑动窗口和字符串 p 中每种字母的数量,而是统计滑动窗口和字符串 p 中每种字母数量的差;并引入变量 differ 来记录当前窗口与字符串 p 中数量不同的字母的个数,并在滑动窗口的过程中维护它。
在判断滑动窗口中每种字母的数量与字符串 p 中每种字母的数量是否相同时,只需要判断 differ 是否为零即可。
时间复杂度:O(n+(m−n)×Σ),其中 m 为字符串 s 的长度,n 为字符串 p 的长度,Σ 为所有可能的字符数。我们需要 O(n) 来统计字符串 p 中每种字母的数量;需要 O(n) 来初始化滑动窗口;需要判断 m−n+1 个滑动窗口中每种字母的数量是否与字符串 p 中每种字母的数量相同,每次判断需要 O(Σ) 。因为 s 和 p 仅包含小写字母,所以 Σ=26。
空间复杂度:O(Σ)。用于存储字符串 p 和滑动窗口中每种字母的数量。
2、优化的滑动窗口
时间复杂度:O(m+n+Σ),其中 m 为字符串 s 的长度,n 为字符串 p 的长度,其中 Σ 为所有可能的字符数。我们需要 O(n) 来统计字符串 p 中每种字母的数量;需要 O(n) 来初始化滑动窗口;需要 O(Σ) 来初始化 differ;需要 O(m−n) 来滑动窗口并判断窗口内每种字母的数量是否与字符串 p 中每种字母的数量相同,每次判断需要 O(1) 。因为 s 和 p 仅包含小写字母,所以 Σ=26。