色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

詳解無重復字符的最長子串

算法與數據結構 ? 來源:吳師兄學算法 ? 作者:吳師兄 ? 2022-09-06 11:56 ? 次閱讀

一、題目描述

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

示例 1:

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

示例 2:

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

示例 3:

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

提示:

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

s由英文字母、數字、符號和空格組成

二、題目解析

很經典的滑動窗口的題目。

具體操作如下:

1、定義需要維護的變量,對于此題來說,要求是最大長度,同時又涉及去重,因此需要一個哈希表。

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

3、窗口的右端位置從 0 開始,可以一直移動到尾部。

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

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

5、此時,滑動窗口可以接納新增元素。

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

三、參考代碼

1、Java 代碼

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

//滑動窗口模板化解題,五步走策略

//【1、定義需要維護的變量】

//對于此題來說,要求是最大長度
intmaxLen=0;

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

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

//窗口的左端位置從0開始
intstart=0;

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

2、C++ 代碼

classSolution{
public:
intlengthOfLongestSubstring(strings){

//滑動窗口模板化解題,五步走策略

//【1、定義需要維護的變量】

//對于此題來說,要求是最大長度
intmaxLen=0;

//同時又涉及去重,因此需要一個哈希表
unordered_sethash;

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

//窗口的左端位置從0開始
intstart=0;

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

3、Python 代碼

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

#【1、定義需要維護的變量】

#對于此題來說,要求是最大長度
maxLen=0

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

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

#窗口的左端位置從0開始
start=0

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

#【3、更新需要維護的變量,有的變量需要一個if語句來維護(比如最大最小長度)】

#【4、如果題目的窗口長度可變:這個時候一般涉及到窗口是否合法的問題】
#如果當前窗口不合法時,用一個while去不斷移動窗口左指針,從而剔除非法元素直到窗口再次合法

#如果哈希表中存儲了即將加入滑動窗口的元素
whiles[end]inhash:

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

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

#窗口左端向右移動
start+=1

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

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

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

四、復雜度分析

時間復雜度:O(N),其中 N是字符串的長度。左指針和右指針分別會遍歷整個字符串一次。

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



審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • JAVA
    +關注

    關注

    19

    文章

    2970

    瀏覽量

    104824
  • 字符串
    +關注

    關注

    1

    文章

    579

    瀏覽量

    20546
  • python
    +關注

    關注

    56

    文章

    4797

    瀏覽量

    84776

原文標題:LeetCode 3:無重復字符的最長子串

文章出處:【微信號:TheAlgorithm,微信公眾號:算法與數據結構】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    字符串處理:4G模組軟件指南精要!

    最近一直有朋友咨詢我關于4G模組的字符串處理,今天我便把相關指南展示給大家。
    的頭像 發表于 11-17 09:57 ?226次閱讀
    <b class='flag-5'>字符串</b>處理:4G模組軟件指南精要!

    base64字符串轉換為二進制文件

    Base64是一種編碼方法,用于將二進制數據轉換為ASCII字符串。這種編碼通常用于在不支持二進制數據的系統中傳輸數據,例如電子郵件或網頁。將Base64字符串轉換為二進制文件的過程相對簡單,但需要
    的頭像 發表于 11-10 10:55 ?1243次閱讀

    MATLAB(5)--字符串處理

    字符串表示 在MATLAB中,字符串是用單引號括起來的字符序列,是把一個字符串當做一個行向量,這個行向量中,每個元素對應一個字符。 若
    發表于 09-06 10:22

    labview字符串數組轉化為數值數組

    在LabVIEW中,將字符串數組轉換為數值數組是一項常見的任務,尤其是在處理數據采集、信號處理或用戶輸入時。 1. 理解LabVIEW的數據類型 在開始之前,了解LabVIEW中的數據類型是非
    的頭像 發表于 09-04 17:47 ?2453次閱讀

    labview字符串如何轉換為16進制字符串

    在LabVIEW中,將字符串轉換為16進制字符串是一個常見的需求,尤其是在處理數據通信和硬件接口時。LabVIEW提供了多種方法來實現這一轉換,包括使用內置函數、編寫VI(Virtual
    的頭像 發表于 09-04 15:54 ?2598次閱讀

    labview中如何實現字符串換行

    1. 字符串換行的基本概念 在LabVIEW中,字符串換行通常指的是在字符串中插入換行符,使得字符串在顯示或輸出時能夠自動換行。這在創建用戶界面或處理文本數據時非常有用。 2.
    的頭像 發表于 09-04 15:47 ?1781次閱讀

    labview中如何實現字符串選擇輸出

    在LabVIEW中實現字符串選擇輸出是一項常見的任務,它涉及到字符串處理、條件判斷和用戶界面設計等多個方面。由于LabVIEW是一種圖形化編程語言,其編程方式與傳統的文本編程語言有所不同,因此實現
    的頭像 發表于 09-04 15:44 ?974次閱讀

    labview中常用的字符串函數有哪些?

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

    labview字符串的四種表示各有什么特點

    。在LabVIEW中,字符串是一種基本的數據類型,用于表示文本信息。字符串在LabVIEW中有多種表示方式,每種方式都有其特定的應用場景和特點。以下是對LabVIEW中四種字符串表示方式的分析: 1.
    的頭像 發表于 09-04 15:40 ?607次閱讀

    如何向ESP8266發送字符串

    我們正在開發一個應用程序,其中需要通過 Internet 將字符串字符(例如“1x,7juyss”)從移動設備發送到ESP8266。我們已經閱讀了 Cloud API 文檔,但沒有提到傳遞字符串參數。此外,Data Stream
    發表于 07-15 06:58

    銳評Ruby 3.4.0 默認啟用字符串字面量凍結功能

    據悉,Ruby自2.3版起引入了“凍結”機制,通過使用frozen_string_literal: true魔法注釋,可令文件內所有字符串字面量默認為凍結狀態,防止開發過程中無意修改字符串,提高代碼穩定性與性能,降低內存占用。
    的頭像 發表于 05-17 15:44 ?395次閱讀

    如何提取串口接收字符串數組里的某個字符串

    前幾天搞了好久串口發送接收字符串的程序代碼,終于搞出來了。還沒高興多久,新的問題又來了。我使用STM8S105K4的UART2口跟藍牙模塊通信的,我發送字符串指令給藍牙后,藍牙返回來了十幾
    發表于 04-22 06:05

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

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

    C語言字符串編譯函數介紹

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

    USB字符串描述符里面的序列號字符串到底是什么東西?

    在設備描述符里面,有一個表示序列號字符串描述符的編號,請問這個序列號字符串的描述符是什么東西呢? 廠商字符串和設備字符串都能理解,而且在電腦的“設備與打印機”里面都找到了。但請問這個
    發表于 01-24 08:06
    主站蜘蛛池模板: 久久黄色录像| 十分钟在线观看免费视频高清WWW| 午夜性爽视频男人的天堂在线| 父亲猜女儿在线观看| 桃色园社区| 国产在线精品亚洲一品区| 在线视频久久只有精品第一日韩| 米奇影视999| 贵妃高h荡肉呻吟np杨玉环| 亚洲AV无码A片在线观看蜜桃| 久久嫩草影院网站| 大胸美女被c| 一二三四中文字幕在线看| 欧美人成人亚洲专区中文字幕| 国产精品久久久久久久久无码| 伊人久久中文| 色爱区综合激情五月综合激情| 激情内射亚洲一区二区三区| JAPANRCEP老熟妇乱子伦视频| 亚欧视频在线观看| 欧美 亚洲 日韩 在线综合| 国产美女一区二区| 97久久久久| 亚洲AV 无码AV 中文字幕| 嫩草影院在线观看精品视频| 国产亚洲精品免费视频| a在线观看免费视频| 亚洲AV精品无码国产一区| 男女夜晚在爽视频免费观看| 国产系列视频二区| www.色小姐| 真实处破女全过程完免费观看 | 高清一区二区亚洲欧美日韩| 印度最猛性ⅹxxxxx| 甜性涩爱全集在线观看| 蜜臀久久99精品久久久久久做爰 | 韩剧甜性涩爱| 成人免费观看国产高清| 综合伊人久久| 亚洲欧美日韩国产手机在线| 丝瓜视频樱桃视频在线观看免费|