题目大意
- 在一个字符串重寻找没有重复字母的最长子串。
- 滑动窗口的右边界不断的右移,只要没有重复的字符,就持续向右扩大窗口边界。一旦出现了重复字符,就需要缩小左边界,直到重复的字符移出了左边界,然后继续移动滑动窗口的右边界。以此类推,每次移动需要计算当前长度,并判断是否需要更新最大长度,最终最大的值就是题目中的所求。
package main
import "fmt"
// 滑动窗口
// ASCII码,127位
// 只要没有重复,freq数组该ASCII码的位值+1
// 遇到重复,freq数组该位有值,则重复
// 这时候,right +1 就是最大值
// 依次遍历字符串,直到字符串结束
func lengthOfLongestSubstring(s string) int {
if len(s) == 0 {
return 0
}
var freq [127]int
result, left, right := 0, 0, -1
for left < len(s) {
if right+1 < len(s) && freq[s[right+1]] == 0 {
freq[s[right+1]]++
right++
} else {
freq[s[left]]--
left++
}
result = max(result, right-left+1)
}
return result
}
func max(a int, b int) int {
if a > b {
return a
}
return b
}
func main() {
var str = "abcab"
fmt.Println(lengthOfLongestSubstring(str))
}