-
Notifications
You must be signed in to change notification settings - Fork 172
/
Copy pathLonges_substring_without_repeating_characters.cpp
41 lines (31 loc) · 1.38 KB
/
Longes_substring_without_repeating_characters.cpp
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
32
33
34
35
36
37
38
39
40
41
#include <iostream>
#include <unordered_map>
#include <string>
using namespace std;
int lengthOfLongestSubstring(string s) {
unordered_map<char, int> charIndexMap;
int left = 0; // left pointer of the sliding window
int maxLength = 0; // stores the maximum length of the substring without repeating characters
// Iterate through the string with the right pointer
for (int right = 0; right < s.length(); right++) {
char currentChar = s[right];
// If the current character is already in the map and its index is within the current window,
// move the left pointer to one position right of the last occurrence of the current character.
if (charIndexMap.find(currentChar) != charIndexMap.end() && charIndexMap[currentChar] >= left) {
left = charIndexMap[currentChar] + 1;
}
// Update the map with the current character's latest index.
charIndexMap[currentChar] = right;
// Calculate the length of the current window and update maxLength if necessary.
maxLength = max(maxLength, right - left + 1);
}
return maxLength;
}
int main() {
string s;
cout << "Enter a string: ";
cin >> s;
int result = lengthOfLongestSubstring(s);
cout << "Length of the longest substring without repeating characters: " << result << endl;
return 0;
}