Skip to content

Commit e2b99e0

Browse files
authored
Create Maximum Sub-String after at most K changes
nov 12
1 parent b45d6d4 commit e2b99e0

File tree

1 file changed

+40
-0
lines changed

1 file changed

+40
-0
lines changed
+40
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
class Solution {
2+
public:
3+
int characterReplacement(string s, int k) {
4+
int maxLen = 0;
5+
int cnt = 0;
6+
int i = 0;
7+
int j = 0;
8+
unordered_set<char> st;
9+
for(auto &e: s){
10+
st.insert(e);
11+
}
12+
for(auto &e : st){
13+
int currLen = 0;
14+
int cnt = 0;
15+
int i = 0;
16+
int j = 0;
17+
while(j < s.size()){
18+
if(s[j] == e){
19+
currLen++;
20+
maxLen = std::max(currLen, maxLen);
21+
j++;
22+
}
23+
else{
24+
cnt++;
25+
currLen++;
26+
while(cnt > k && i <= j){
27+
if(e != s[i])
28+
cnt--;
29+
i++;
30+
currLen--;
31+
}
32+
maxLen = std::max(currLen, maxLen);
33+
j++;
34+
}
35+
}
36+
}
37+
return maxLen;
38+
}
39+
40+
};

0 commit comments

Comments
 (0)