0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

詳解無(wú)重復(fù)字符的最長(zhǎng)子串

算法與數(shù)據(jù)結(jié)構(gòu) ? 來(lái)源:吳師兄學(xué)算法 ? 作者:吳師兄 ? 2022-09-06 11:56 ? 次閱讀

一、題目描述

給定一個(gè)字符串s,請(qǐng)你找出其中不含有重復(fù)字符的最長(zhǎng)子串的長(zhǎng)度。

示例 1:

輸入:s="abcabcbb"
輸出:3
解釋:因?yàn)闊o(wú)重復(fù)字符的最長(zhǎng)子串是"abc",所以其長(zhǎng)度為 3。

示例 2:

輸入:s="bbbbb"
輸出:1
解釋:因?yàn)闊o(wú)重復(fù)字符的最長(zhǎng)子串是"b",所以其長(zhǎng)度為 1。

示例 3:

輸入:s="pwwkew"
輸出:3
解釋:因?yàn)闊o(wú)重復(fù)字符的最長(zhǎng)子串是"wke",所以其長(zhǎng)度為 3。
請(qǐng)注意,你的答案必須是子串的長(zhǎng)度,"pwke"是一個(gè)子序列,不是子串。

提示:

0 <= s.length <= 5 * 10^4

s由英文字母、數(shù)字、符號(hào)和空格組成

二、題目解析

很經(jīng)典的滑動(dòng)窗口的題目。

具體操作如下:

1、定義需要維護(hù)的變量,對(duì)于此題來(lái)說(shuō),要求是最大長(zhǎng)度,同時(shí)又涉及去重,因此需要一個(gè)哈希表。

2、定義窗口的首尾端 (start, end), 然后滑動(dòng)窗口。

3、窗口的右端位置從 0 開(kāi)始,可以一直移動(dòng)到尾部。

4、如果哈希表中存儲(chǔ)了即將加入滑動(dòng)窗口的元素,那么需要不斷的把窗口左邊的元素移除窗口。

d82ffca6-2d92-11ed-ba43-dac502259ad0.pngd8437a56-2d92-11ed-ba43-dac502259ad0.png

5、此時(shí),滑動(dòng)窗口可以接納新增元素。

d854e980-2d92-11ed-ba43-dac502259ad0.png

三、參考代碼

1、Java 代碼

//登錄AlgoMooc官網(wǎng)獲取更多算法圖解
//https://www.algomooc.com
//作者:程序員吳師兄
//代碼有看不懂的地方一定要私聊咨詢吳師兄呀
//無(wú)重復(fù)字符的最長(zhǎng)子串(LeetCode 3):https://leetcode.cn/problems/longest-substring-without-repeating-characters/
classSolution{
publicintlengthOfLongestSubstring(Strings){

//滑動(dòng)窗口模板化解題,五步走策略

//【1、定義需要維護(hù)的變量】

//對(duì)于此題來(lái)說(shuō),要求是最大長(zhǎng)度
intmaxLen=0;

//同時(shí)又涉及去重,因此需要一個(gè)哈希表
HashSethash=newHashSet();

//【2、定義窗口的首尾端(start,end),然后滑動(dòng)窗口】

//窗口的左端位置從0開(kāi)始
intstart=0;

//窗口的右端位置從0開(kāi)始,可以一直移動(dòng)到尾部
for(intend=0;end

2、C++ 代碼

classSolution{
public:
intlengthOfLongestSubstring(strings){

//滑動(dòng)窗口模板化解題,五步走策略

//【1、定義需要維護(hù)的變量】

//對(duì)于此題來(lái)說(shuō),要求是最大長(zhǎng)度
intmaxLen=0;

//同時(shí)又涉及去重,因此需要一個(gè)哈希表
unordered_sethash;

//【2、定義窗口的首尾端(start,end),然后滑動(dòng)窗口】

//窗口的左端位置從0開(kāi)始
intstart=0;

//窗口的右端位置從0開(kāi)始,可以一直移動(dòng)到尾部
for(intend=0;end

3、Python 代碼

classSolution:
deflengthOfLongestSubstring(self,s:str)->int:
#滑動(dòng)窗口模板化解題,五步走策略

#【1、定義需要維護(hù)的變量】

#對(duì)于此題來(lái)說(shuō),要求是最大長(zhǎng)度
maxLen=0

#同時(shí)又涉及去重,因此需要一個(gè)哈希表
hash=set()

#【2、定義窗口的首尾端(start,end),然后滑動(dòng)窗口】

#窗口的左端位置從0開(kāi)始
start=0

#窗口的右端位置從0開(kāi)始,可以一直移動(dòng)到尾部
forendinrange(len(s)):

#【3、更新需要維護(hù)的變量,有的變量需要一個(gè)if語(yǔ)句來(lái)維護(hù)(比如最大最小長(zhǎng)度)】

#【4、如果題目的窗口長(zhǎng)度可變:這個(gè)時(shí)候一般涉及到窗口是否合法的問(wèn)題】
#如果當(dāng)前窗口不合法時(shí),用一個(gè)while去不斷移動(dòng)窗口左指針,從而剔除非法元素直到窗口再次合法

#如果哈希表中存儲(chǔ)了即將加入滑動(dòng)窗口的元素
whiles[end]inhash:

#那么需要不斷的把窗口左邊的元素移除窗口

#把s.charAt(start)移除記錄
hash.remove(s[start])

#窗口左端向右移動(dòng)
start+=1

#此時(shí),滑動(dòng)窗口可以接納s.charAt(end)
hash.add(s[end])

#維護(hù)變量maxLen
maxLen=max(maxLen,end-start+1)

#【5、返回所需要的答案】
returnmaxLen

四、復(fù)雜度分析

時(shí)間復(fù)雜度:O(N),其中 N是字符串的長(zhǎng)度。左指針和右指針?lè)謩e會(huì)遍歷整個(gè)字符串一次。

空間復(fù)雜度:O(∣Σ∣),其中 Σ 表示字符集(即字符串中可以出現(xiàn)的字符),∣Σ∣ 表示字符集的大小。



審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • JAVA
    +關(guān)注

    關(guān)注

    19

    文章

    2973

    瀏覽量

    104955
  • 字符串
    +關(guān)注

    關(guān)注

    1

    文章

    585

    瀏覽量

    20577
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4807

    瀏覽量

    84937

原文標(biāo)題:LeetCode 3:無(wú)重復(fù)字符的最長(zhǎng)子串

文章出處:【微信號(hào):TheAlgorithm,微信公眾號(hào):算法與數(shù)據(jù)結(jié)構(gòu)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    字符串在數(shù)據(jù)庫(kù)中的存儲(chǔ)方式

    數(shù)據(jù)庫(kù)是現(xiàn)代信息技術(shù)中存儲(chǔ)和管理數(shù)據(jù)的核心組件。字符串作為最常見(jiàn)的數(shù)據(jù)類型之一,在數(shù)據(jù)庫(kù)中的存儲(chǔ)方式對(duì)其性能和可擴(kuò)展性有著重要影響。 數(shù)據(jù)類型 固定長(zhǎng)度字符串 :如CHAR類型,它為每個(gè)字符串分配
    的頭像 發(fā)表于 01-07 15:41 ?168次閱讀

    字符串在編程中的應(yīng)用實(shí)例

    字符串在編程中有著廣泛的應(yīng)用,它們被用于表示文本數(shù)據(jù)、處理用戶輸入、構(gòu)建動(dòng)態(tài)內(nèi)容等。以下是一些字符串在編程中的應(yīng)用實(shí)例: 1. 用戶輸入與輸出 用戶輸入 :程序通常需要從用戶那里獲取輸入,這些輸入通
    的頭像 發(fā)表于 01-07 15:33 ?126次閱讀

    字符串字符數(shù)組的區(qū)別

    在編程語(yǔ)言中,字符串字符數(shù)組是兩種基本的數(shù)據(jù)結(jié)構(gòu),它們都用于存儲(chǔ)和處理文本數(shù)據(jù)。盡管它們?cè)诠δ苌嫌幸欢ǖ闹丿B,但在內(nèi)部表示、操作方式和使用場(chǎng)景上存在顯著差異。 1. 內(nèi)部表示 字符串 字符串
    的頭像 發(fā)表于 01-07 15:29 ?242次閱讀

    字符串反轉(zhuǎn)的實(shí)現(xiàn)方式

    在編程中,字符串反轉(zhuǎn)是一個(gè)基礎(chǔ)而重要的操作,它涉及到將一個(gè)字符串中的字符順序顛倒過(guò)來(lái)。這個(gè)操作在多種編程語(yǔ)言中都有不同的實(shí)現(xiàn)方式,本文將探討幾種常見(jiàn)的字符串反轉(zhuǎn)方法。 1. 遞歸方法
    的頭像 發(fā)表于 01-07 15:27 ?180次閱讀

    字符串處理方法 字符串轉(zhuǎn)數(shù)字的實(shí)現(xiàn)

    在編程中,將字符串轉(zhuǎn)換為數(shù)字是一個(gè)常見(jiàn)的需求。不同的編程語(yǔ)言有不同的方法來(lái)實(shí)現(xiàn)這一功能。以下是一些常見(jiàn)編程語(yǔ)言中的字符串轉(zhuǎn)數(shù)字的實(shí)現(xiàn)方法: Python 在Python中,可以使用內(nèi)置的 int
    的頭像 發(fā)表于 01-07 15:26 ?165次閱讀

    base64字符串轉(zhuǎn)換為二進(jìn)制文件

    Base64是一種編碼方法,用于將二進(jìn)制數(shù)據(jù)轉(zhuǎn)換為ASCII字符串。這種編碼通常用于在不支持二進(jìn)制數(shù)據(jù)的系統(tǒng)中傳輸數(shù)據(jù),例如電子郵件或網(wǎng)頁(yè)。將Base64字符串轉(zhuǎn)換為二進(jìn)制文件的過(guò)程相對(duì)簡(jiǎn)單,但需要
    的頭像 發(fā)表于 11-10 10:55 ?1584次閱讀

    MATLAB(5)--字符串處理

    字符串表示 在MATLAB中,字符串是用單引號(hào)括起來(lái)的字符序列,是把一個(gè)字符串當(dāng)做一個(gè)行向量,這個(gè)行向量中,每個(gè)元素對(duì)應(yīng)一個(gè)字符。 若
    發(fā)表于 09-06 10:22

    labview字符串數(shù)組轉(zhuǎn)化為數(shù)值數(shù)組

    在LabVIEW中,將字符串數(shù)組轉(zhuǎn)換為數(shù)值數(shù)組是一項(xiàng)常見(jiàn)的任務(wù),尤其是在處理數(shù)據(jù)采集、信號(hào)處理或用戶輸入時(shí)。 1. 理解LabVIEW的數(shù)據(jù)類型 在開(kāi)始之前,了解LabVIEW中的數(shù)據(jù)類型是非
    的頭像 發(fā)表于 09-04 17:47 ?2756次閱讀

    labview字符串如何轉(zhuǎn)換為16進(jìn)制字符串

    在LabVIEW中,將字符串轉(zhuǎn)換為16進(jìn)制字符串是一個(gè)常見(jiàn)的需求,尤其是在處理數(shù)據(jù)通信和硬件接口時(shí)。LabVIEW提供了多種方法來(lái)實(shí)現(xiàn)這一轉(zhuǎn)換,包括使用內(nèi)置函數(shù)、編寫VI(Virtual
    的頭像 發(fā)表于 09-04 15:54 ?2930次閱讀

    labview中如何實(shí)現(xiàn)字符串選擇輸出

    在LabVIEW中實(shí)現(xiàn)字符串選擇輸出是一項(xiàng)常見(jiàn)的任務(wù),它涉及到字符串處理、條件判斷和用戶界面設(shè)計(jì)等多個(gè)方面。由于LabVIEW是一種圖形化編程語(yǔ)言,其編程方式與傳統(tǒng)的文本編程語(yǔ)言有所不同,因此實(shí)現(xiàn)
    的頭像 發(fā)表于 09-04 15:44 ?1051次閱讀

    labview中常用的字符串函數(shù)有哪些?

    在LabVIEW中,常用的字符串函數(shù)廣泛覆蓋了對(duì)字符串的各種操作,包括但不限于格式化、搜索、替換、連接、計(jì)算長(zhǎng)度等。以下是一些常用的字符串函數(shù)及其簡(jiǎn)要說(shuō)明: 字符串長(zhǎng)度(String
    的頭像 發(fā)表于 09-04 15:43 ?929次閱讀

    labview字符串的四種表示各有什么特點(diǎn)

    。在LabVIEW中,字符串是一種基本的數(shù)據(jù)類型,用于表示文本信息。字符串在LabVIEW中有多種表示方式,每種方式都有其特定的應(yīng)用場(chǎng)景和特點(diǎn)。以下是對(duì)LabVIEW中四種字符串表示方式的分析: 1.
    的頭像 發(fā)表于 09-04 15:40 ?675次閱讀

    銳評(píng)Ruby 3.4.0 默認(rèn)啟用字符串字面量?jī)鼋Y(jié)功能

    據(jù)悉,Ruby自2.3版起引入了“凍結(jié)”機(jī)制,通過(guò)使用frozen_string_literal: true魔法注釋,可令文件內(nèi)所有字符串字面量默認(rèn)為凍結(jié)狀態(tài),防止開(kāi)發(fā)過(guò)程中無(wú)意修改字符串,提高代碼穩(wěn)定性與性能,降低內(nèi)存占用。
    的頭像 發(fā)表于 05-17 15:44 ?417次閱讀

    鴻蒙TypeScript學(xué)習(xí)第10天:【String(字符串)】

    String 對(duì)象用于處理文本(字符串)。
    的頭像 發(fā)表于 04-08 14:32 ?869次閱讀
    鴻蒙TypeScript學(xué)習(xí)第10天:【String(<b class='flag-5'>字符串</b>)】

    C語(yǔ)言字符串編譯函數(shù)介紹

    在C語(yǔ)言中,字符串實(shí)際上是使用null字符O'終止的一維字符數(shù)組。因此,一個(gè)以null結(jié)尾的字符串,包含了組成字符串
    的頭像 發(fā)表于 03-07 16:18 ?534次閱讀
    C語(yǔ)言<b class='flag-5'>字符串</b>編譯函數(shù)介紹