chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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)注

    20

    文章

    2998

    瀏覽量

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

    關(guān)注

    1

    文章

    596

    瀏覽量

    23153
  • python
    +關(guān)注

    關(guān)注

    57

    文章

    4869

    瀏覽量

    89939

原文標(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)推薦
    熱點(diǎn)推薦

    字符串控件與靜態(tài)字符串控件中預(yù)覽字符顯示亂碼,如何修改顯示正常?

    字符串控件與靜態(tài)字符串控件中預(yù)覽字符顯示亂碼,如何修改顯示正常?
    發(fā)表于 01-20 17:17

    字符串,數(shù)字控件如何控制背景顏色和前景字體顏色?

    字符串,數(shù)字控件如何控制背景顏色和前景字體顏色?
    發(fā)表于 01-20 15:12

    Linux下怎么讓中文字符串按照拼音排序?

    求教 Linux 下怎么讓中文字符串按照拼音排序?
    發(fā)表于 01-06 07:40

    德州儀器SDI解器LMH0041、LMH0051、LMH0071、LMH0341詳解

    德州儀器SDI解器LMH0041、LMH0051、LMH0071、LMH0341詳解 在數(shù)字視頻信號(hào)處理領(lǐng)域,德州儀器(TI)的LMH0041、LMH0051、LMH0071和LMH0341
    的頭像 發(fā)表于 12-25 17:10 ?590次閱讀

    探索LMH0041、LMH0051、LMH0071、LMH0341 SDI解器:功能、特性與應(yīng)用詳解

    探索LMH0041、LMH0051、LMH0071、LMH0341 SDI解器:功能、特性與應(yīng)用詳解 在當(dāng)今的數(shù)字視頻領(lǐng)域,SDI(Serial Digital Interface)接口因其高速
    的頭像 發(fā)表于 12-25 16:55 ?658次閱讀

    汽車級(jí)FPD - Link III解器DS90UB934 - Q1:技術(shù)詳解與應(yīng)用指南

    汽車級(jí)FPD - Link III解器DS90UB934 - Q1:技術(shù)詳解與應(yīng)用指南 在汽車電子和工業(yè)成像等領(lǐng)域,高速可靠的視頻傳輸和數(shù)據(jù)控制是關(guān)鍵需求。DS90UB934 - Q1作為一款專為
    的頭像 發(fā)表于 12-19 09:25 ?362次閱讀

    字符串關(guān)聯(lián)數(shù)字變量如何使用?我們的地址都是16位數(shù)據(jù),可以使用16位數(shù)字變量顯示字符串嗎?

    字符串關(guān)聯(lián)數(shù)字變量如何使用?我們的地址都是16位數(shù)據(jù),可以使用16位數(shù)字變量顯示字符串嗎?
    發(fā)表于 12-15 08:24

    精密平臺(tái)中重復(fù)精度的影響因素有哪些

    什么是重復(fù)定位精度? ? ? 在精密運(yùn)動(dòng)平臺(tái)中,重復(fù)定位精度(或重復(fù)性)是指運(yùn)動(dòng)臺(tái)多次運(yùn)動(dòng)到同一名義位置時(shí),與實(shí)際位置偏差的某個(gè)統(tǒng)計(jì)量,根據(jù)不同的測(cè)試標(biāo)準(zhǔn)會(huì)有不同的統(tǒng)計(jì)計(jì)算方法,例如峰谷值、2σ、3
    的頭像 發(fā)表于 10-15 11:24 ?696次閱讀
    精密平臺(tái)中<b class='flag-5'>重復(fù)</b>精度的影響因素有哪些

    非對(duì)稱密鑰生成和轉(zhuǎn)換規(guī)格詳解

    當(dāng)前章節(jié)將說(shuō)明系統(tǒng)目前支持的算法及其對(duì)應(yīng)的規(guī)格。密鑰生成有兩種指定規(guī)格的方式,分別是: 字符串參數(shù):以字符串的形式描述開(kāi)發(fā)者需要生成的密鑰規(guī)格。 密鑰參數(shù):使用密鑰的詳細(xì)密碼學(xué)信息,構(gòu)造密鑰對(duì)象
    發(fā)表于 09-01 07:50

    LM3466 多 LED 電流平衡器技術(shù)手冊(cè)

    到電源的數(shù)或每個(gè) LED 的正向電壓 字符串。 如果任何 LED 燈在運(yùn)行過(guò)程中打開(kāi),LM3466 會(huì)自動(dòng)平衡通過(guò)所有剩余活動(dòng) LED 燈的電源電流。 如 因此,即使一些 LED
    的頭像 發(fā)表于 08-29 14:27 ?1024次閱讀
    LM3466 多<b class='flag-5'>串</b> LED 電流平衡器技術(shù)手冊(cè)

    labview如何生成一個(gè)帶字符串返回的dll

    labview如何生成一個(gè)dll,如下圖,要求一個(gè)輸入,類型是字符串,返回類型也是字符串
    發(fā)表于 08-28 23:20

    在Python中字符串逆序有幾種方式,代碼是什么

    對(duì)于一個(gè)給定的字符串,逆序輸出,這個(gè)任務(wù)對(duì)于python來(lái)說(shuō)是一種很簡(jiǎn)單的操作,畢竟強(qiáng)大的列表和字符串處理的一些列函數(shù)足以應(yīng)付這些問(wèn)題 了,今天總結(jié)了一下python中對(duì)于字符串的逆序輸出的幾種常用
    的頭像 發(fā)表于 08-28 14:44 ?1024次閱讀

    linux系統(tǒng)awk特殊字符命令詳解

    在Linux系統(tǒng)中,awk?是一種非常強(qiáng)大的文本處理工具,能夠?qū)ξ谋緮?shù)據(jù)進(jìn)行分析、格式化和篩選。利用其內(nèi)置的特殊字符和操作符,用戶可以實(shí)現(xiàn)復(fù)雜的數(shù)據(jù)處理任務(wù)。以下對(duì)一些常見(jiàn)的awk特殊字符和操作符
    的頭像 發(fā)表于 07-28 16:38 ?602次閱讀

    harmony-utils之StrUtil,字符串工具類

    harmony-utils之StrUtil,字符串工具類 harmony-utils 簡(jiǎn)介與說(shuō)明 [harmony-utils] 一款功能豐富且極易上手的HarmonyOS工具庫(kù),借助眾多實(shí)用工具類
    的頭像 發(fā)表于 07-03 11:32 ?587次閱讀

    STM32C031C6使用的是UART2通訊,通過(guò)printf()函數(shù)發(fā)送字符串時(shí),漢字錯(cuò)碼怎么解決?

    使用的是UART2通訊,通過(guò)printf()函數(shù)發(fā)送字符串時(shí),漢字錯(cuò)碼(見(jiàn)下圖),應(yīng)該是KEIL哪里沒(méi)有設(shè)置好的問(wèn)題。 啟用了UART2的中斷接收,可以接收到串口調(diào)試助手的數(shù)據(jù),但是緩存區(qū)的指針沒(méi)有歸零,下次接收時(shí)緩存區(qū)中的內(nèi)容接續(xù)(如下圖所示),不知道用什么命令來(lái)清除緩存區(qū)(即讓指針歸零)。
    發(fā)表于 03-07 12:30