给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
时间: 2023-10-14 09:30:39 浏览: 94
这道题可以使用滑动窗口的方法进行解决。使用两个指针 left 和 right 分别表示子串的左右边界,然后使用一个哈希表记录每个字符最后一次出现的位置。遍历字符串 s,每次将右指针向右移动一位,如果遇到的字符在哈希表中已经存在,则说明当前子串中有重复字符,需要将左指针移动到上一个该字符出现的位置的下一位,以保证子串中没有重复字符。在每次移动右指针和左指针时,记录当前子串的长度并更新最长子串的长度。
以下是代码实现:
```python
def lengthOfLongestSubstring(s: str) -> int:
if not s:
return 0
left = 0
right = 0
max_len = 0
char_map = {}
while right < len(s):
if s[right] in char_map and char_map[s[right]] >= left:
left = char_map[s[right]] + 1
char_map[s[right]] = right
max_len = max(max_len, right - left + 1)
right += 1
return max_len
```
时间复杂度为 O(n),空间复杂度为 O(min(m, n)),其中 n 是字符串的长度,m 是字符集的大小。
相关问题
给定一个字符串,请你找出其中不含有重复字符的最长子串的长度
题目描述:
给定一个字符串,请你找出其中不含有重复字符的最长子串的长度。
示例 1:
输入: "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:
输入: "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:
输入: "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
解题思路:
使用滑动窗口的思想,维护一个窗口,窗口内的元素不重复,每次移动右边界,如果右边界的元素在窗口内出现过,则移动左边界,直到窗口内不再有重复元素。
代码实现:
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度
你的问题可以通过使用滑动窗口算法来解决。具体实现如下:
1. 定义一个字典来存储字符和它们在字符串中的最近一次出现的索引。
2. 定义两个指针 left 和 right,分别指向子串的左右边界。
3. 当右指针指向的字符在字典中已经存在时,更新左指针的位置为该字符在字典中的最近一次出现的索引加1。
4. 在遍历过程中,记录每个不重复子串的最大长度,并返回该长度。
以下是实现代码:
```
def lengthOfLongestSubstring(s: str) -> int:
char_dict = {} # 存储每个字符及其最近一次出现的索引
left = 0 # 左指针,子串左边界
max_len = 0 # 不重复子串的最大长度
for i, char in enumerate(s):
if char in char_dict and char_dict[char] >= left:
left = char_dict[char] + 1
char_dict[char] = i
max_len = max(max_len, i - left + 1)
return max_len
```
你可以使用该函数进行测试:
```
s = "abcabcbb"
print(lengthOfLongestSubstring(s)) # 输出3,对应的不重复子串为"abc"
s = "bbbbb"
print(lengthOfLongestSubstring(s)) # 输出1,对应的不重复子串为"b"
s = "pwwkew"
print(lengthOfLongestSubstring(s)) # 输出3,对应的不重复子串为"wke"
s = ""
print(lengthOfLongestSubstring(s)) # 输出0,空字符串不存在不重复子串
s = " "
print(lengthOfLongestSubstrng(s)) # 输出1,空格""为不重复子串
```
阅读全文