zoukankan      html  css  js  c++  java
  • 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关于窗口的解释:

  • 相关阅读:
    JavaScript之数学对象Math
    JavaScript之数据类型转换
    JavaScript之操作符
    JavaScript之基本语句
    JavaScript之基本概念(二)
    JavaScript之基本概念(一)
    使用velero进行kubernetes灾备
    minikube配置CRI-O作为runtime并指定flannel插件
    使用thanos管理Prometheus持久化数据
    linux开启tcp_timestamps和tcp_tw_recycle引发的问题研究
  • 原文地址:https://www.cnblogs.com/gettolive/p/10174916.html
Copyright © 2011-2022 走看看