1. 程式人生 > >LeetCode Golang 3. 無重複字元的最長子串

LeetCode Golang 3. 無重複字元的最長子串

3. 無重複字元的最長子串

給定一個字串,請你找出其中不含有重複字元的 最長子串 的長度。

示例 1:

輸入: "abcabcbb"
輸出: 3 
解釋: 因為無重複字元的最長子串是 "abc",所以其長度為 3。

示例 2:

輸入: "bbbbb"
輸出: 1
解釋: 因為無重複字元的最長子串是 "b",所以其長度為 1。

示例 3:

輸入: "pwwkew"
輸出: 3
解釋: 因為無重複字元的最長子串是 "wke",所以其長度為 3。
     請注意,你的答案必須是 子串 的長度,"pwke"
 是一個子序列,不是子串。

 

方法一: 暴力法  時間複雜度 n3

package main

import (
	"fmt"
	"strings"
)

//給定一個字串,請你找出其中不含有重複字元的 最長子串 的長度。
// 思路 : 找出全部的無重複子串, 統計出最長的
func lengthOfLongestSubstring(s string) int {
	count := 0
	sonStringMap := make(map[string]int)
	// sonString := []string{""}
	for j:=0;j<len(s);j++{
		tmpString := s[j:]
		subString := ""
		for k,v := range []byte(tmpString){
			if strings.Contains(subString,string(v)) {
				sonStringMap[subString]++
				if k == len(tmpString) {
					sonStringMap[subString]++
				}
				subString = ""
			} else {
				subString += string(v)
				if k == len(tmpString)-1 {
					sonStringMap[subString]++
				}
			}
		}
	}
	fmt.Println(sonStringMap)
	for k,_ := range sonStringMap {
		if  count < len(k){
			count = len(k)
		}
	}
	return count
}

func main() {
	s := "alqebriavxoo"
	fmt.Println(lengthOfLongestSubstring(s))
}

 

官方題解:

思路: 如果 s[j]s[j] 在 [i, j) 範圍內有與 j' 重複的字元,我們不需要逐漸增加 i 。 我們可以直接跳過 [i,j'] 範圍內的所有元素,並將 i 變為 j' + 1

func lengthOfLongestSubstring(s string) int {
	n := len(s)
	ans := 0
	subMap := make(map[byte]int)
	for i, j := 0, 0; j < n; j++ {
		if v, ok := subMap[byte(s[j])]; ok {
			if i < v {
				i = v
			}
		}
		if ans < (j - i + 1) {
			ans = j - i + 1
		}
		subMap[byte(s[j])] = j + 1
	}
	return ans
}

 LeetCode關於視窗的解釋: