Giả sử chúng ta có một chuỗi; chúng ta phải tính độ dài của chuỗi con dài nhất T chứa nhiều nhất k ký tự khác nhau.
Vì vậy, nếu đầu vào là s ="eceba", k =2, thì đầu ra sẽ là 3 vì T là "ece" có độ 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 -
-
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 i lên 1)
-
-
ans:=tối đa ans và (j - i + 1)
-
-
trả lại ans
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;
}
};
main() {
Solution ob;
cout << (ob.lengthOfLongestSubstringKDistinct("eceba", 2));
} Đầu vào
"eceba", 2
Đầu ra
3