您好,登錄后才能下訂單哦!
這篇文章主要介紹“python怎么找出無重復字符的最長子串”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“python怎么找出無重復字符的最長子串”文章能幫助大家解決問題。
【題目】
給定一個字符串,請你找出其中不含有重復字符的 最長子串 的長度。
示例 1:
輸入: "abcabcbb"
輸出: 3
解釋: 因為無重復字符的最長子串是 "abc",所以其長度為 3。
示例 2:
輸入: "bbbbb"
輸出: 1
解釋: 因為無重復字符的最長子串是 "b",所以其長度為 1。
示例 3:
輸入: "pwwkew"
輸出: 3
解釋: 因為無重復字符的最長子串是 "wke",所以其長度為 3。
請注意,你的答案必須是 子串 的長度,"pwke" 是一個子序列,不是子串。
【思路】
1、暴力破解:兩層for循環,遍歷所有子串,判斷是否有重復元素,并記錄最長子串長度。
2、hash表:遍歷數組,使用hash存儲元素及其下標。遍歷時,當元素nums[i]存在于hash表時,需要更新其下標,同時更新最長子串長度。
【代碼】
python版本
class Solution:
def lengthOfLongestSubstring(self, s: str) -> int:
d = {}
last_index = 0
res = 0
for i, si in enumerate(s):
# 在dict中,則子串長度可能更長
# last_index更新為d[si] + 1
if si in d and d[si] >= last_index:
res = max(res, i - last_index)
last_index = d[si] + 1
# 更新dict的si
d[si] = i
# 注意,還未和最后一段進行比較
res = max(res, len(s) - last_index)
return res
關于“python怎么找出無重復字符的最長子串”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。