-
-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy path3. Longest Substring Without Repeating Characters
31 lines (30 loc) · 1.31 KB
/
3. Longest Substring Without Repeating Characters
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
//Approach 3 - Integer Array
/*
1.This solution uses an integer array charIndex to store the indices of characters.
2.We eliminate the need for an unordered map by utilizing the array.
3.The maxLength, left, and right pointers are still present.
4.We iterate through the string using the right pointer.
5.We check if the current character has occurred within the current substring by comparing its index in charIndex with left.
6.If the character has occurred, we move the left pointer to the next position after the last occurrence of the character.
7.We update the index of the current character in charIndex.
8.At each step, we update the maxLength by calculating the length of the current substring.
9.We continue the iteration until reaching the end of the string.
10.Finally, we return the maxLength as the length of the longest substring without repeating characters.
Code*/
class Solution {
public:
int lengthOfLongestSubstring(string s) {
int n = s.length();
int maxLen =0;
vector<int>charIndex(128,-1);
int left =0;
for(int right =0;right<n;right++){
if(charIndex[s[right]] >= left){
left = charIndex[s[right]]+1;
}
charIndex[s[right]] = right;
maxLen = max(maxLen,right-left +1);
}
return maxLen;
}
};