Giả sử chúng ta có một chuỗi s; chúng ta phải tìm độ dài của chuỗi con dài nhất t có nhiều nhất 2 ký tự khác nhau.
Vì vậy, nếu đầu vào là "eceba", thì đầu ra sẽ là 3 vì t là "ece" với độ dài của nó là 3.
Để giải quyết vấn đề này, chúng tôi sẽ làm theo các bước sau -
-
Xác định một hàm lengthOfLongestSubstringKDistinct (), điều này sẽ nhận s, k,
-
ans:=0
-
Xác định một bản đồ m
-
n:=kích thước của s, x:=0
-
để khởi tạo j:=0, i:=0, khi j
-
(tăng m [s [j]] lên 1)
-
nếu m [s [j]] giống với 1 thì -
-
(tăng x 1)
-
-
while (x> k và i <=j), do -
-
(giảm m [s [i]] đi 1)
-
nếu m [s [i]] bằng 0 thì -
-
(giảm x đi 1)
-
-
(tăng tôi lên 1)
-
-
ans:=tối đa ans và j - i + 1
-
-
trả lại ans
-
Từ phương thức chính, hãy làm như sau
-
return lengthOfLongestSubstringKDistinct (s, 2)
Ví dụ
Hãy cùng chúng tôi xem cách triển khai sau để hiểu rõ hơn -
#include <bits/stdc++.h>
using namespace std;
class Solution {
public:
int lengthOfLongestSubstringKDistinct(string s, int k){
int ans = 0;
unordered_map<char, int> m;
int n = s.size();
int x = 0;
for (int j = 0, i = 0; j < n; j++) {
m[s[j]]++;
if (m[s[j]] == 1)
x++;
while (x > k && i <= j) {
m[s[i]]--;
if (m[s[i]] == 0)
x--;
i++;
}
ans = max(ans, j - i + 1);
}
return ans;
}
int lengthOfLongestSubstringTwoDistinct(string s){
return lengthOfLongestSubstringKDistinct(s, 2);
}
};
main(){
Solution ob;
cout << (ob.lengthOfLongestSubstringTwoDistinct("eceba"));
} Đầu vào
"eceba"
Đầu ra
3