LeetCode 438. 找到字符串中所有字母异位词

题目描述

🔥 438. 找到字符串中所有字母异位词

思路分析

滑动窗口+哈希表

参考代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
func findAnagrams(s string, p string) []int {
	var res []int
	if len(s) == 0 || len(p) == 0 {
		return res
	}

	need := make(map[byte]int)
	for i := 0; i < len(p); i++ {
		need[p[i]]++
	}

	left, right := 0, 0
	size := len(need)

	for right < len(s) {
		if count, exists := need[s[right]]; exists {
			need[s[right]]--
			if count == 1 {
				size--
			}
		}

		// 当窗口大小等于p的长度时,检查是否是异位词
		if right-left+1 == len(p) {
			if size == 0 {
				res = append(res, left)
			}

			// 缩小窗口
			if count, exists := need[s[left]]; exists {
				need[s[left]]++
				if count == 0 {
					size++
				}
			}

			left++
		}

		right++
	}

	return res
}
1
write your code here

🍏 点击查看 Java 题解

1
write your code here
本文作者:
本文链接: https://hgnulb.github.io/blog/2023/59586946
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处!