title | datePublished | cuid | slug | cover | tags |
---|---|---|---|---|---|
Longest Substring Without Repeating Characters - Leetcode 3 |
Sat Aug 26 2023 14:53:14 GMT+0000 (Coordinated Universal Time) |
clls55rcd000309ladis29sif |
leetcode-0003 |
go, leetcode |
Given a string s
, find the length of the longest substring without repeating characters.
Example 1:
Input: s = "abcabcbb"
Output: 3
Explanation: The answer is "abc", with the length of 3.
Example 2:
Input: s = "bbbbb"
Output: 1
Explanation: The answer is "b", with the length of 1.
Example 3:
Input: s = "pwwkew"
Output: 3
Explanation: The answer is "wke", with the length of 3.
Notice that the answer must be a substring, "pwke" is a subsequence and not a substring.
Constraints:
-
0 <= s.length <= 5 * 10<sup>4</sup>
-
s
consists of English letters, digits, symbols and spaces.
func lengthOfLongestSubstring(s string) int {
charSet := make(map[byte]bool)
l := 0
res := 0
for r, _ := range s {
for charSet[s[r]] {
delete(charSet,s[l])
l++
}
charSet[s[r]] = true
res = max(res, r-l+1)
}
return res
}
func max(a,b int) int {
if a > b{
return a
}
return b
}
This code defines a function lengthOfLongestSubstring
that takes a string s
as input and calculates the length of the longest substring within that string, where all characters in the substring are unique. Let's break down the code step by step:
-
charSet := make(map[byte]bool)
: This line initializes an empty map calledcharSet
, which will be used to keep track of characters encountered in the current substring. -
l := 0
: This initializes a variablel
(short for "left") to 0. It represents the left pointer of the current substring. -
res := 0
: This initializes a variableres
(short for "result") to 0. It will store the length of the longest substring found. -
The first
for
loop iterates over the characters in the input strings
. It uses two variables,r
and_
, wherer
represents the current position (right pointer) in the string. -
Inside the first loop, there's another loop:
for charSet[s[r]]
. This loop checks whether the current characters[r]
is already present in thecharSet
map. If it is, that means the current character is a repeating character, so the algorithm needs to shrink the substring by moving the left pointer (l
) to the right until the repeated character is removed from the substring. -
Inside the inner loop,
delete(charSet, s[l])
removes the character at thel
position from thecharSet
map, effectively shifting the left pointer to the right. -
After the inner loop,
charSet[s[r]] = true
adds the current character to thecharSet
map, indicating its presence in the current substring. -
res = max(res, r-l+1)
: This calculates the length of the current substring (froml
tor
) and compares it to the current maximum length stored inres
. Whichever is greater becomes the new value ofres
. -
The function
max(a, b int)
is defined to return the maximum of two integersa
andb
. -
Finally, the function returns the value of
res
, which represents the length of the longest substring with unique characters.
In summary, this code uses a sliding window approach to find the longest substring without repeating characters within the given input string s
. The charSet
map keeps track of characters in the current substring, and the left and right pointers (l
and r
) control the window boundaries. The result is stored in the res
variable and returned at the end.