gary@interview:~/interview/coding/340-longest-subs….md$
$ cat ./coding/340-longest-substring-with-at-most-k-distinct-character.md
[Coding]

340. Longest Substring with At Most K Distinct Character

────────────────────────────────────────────────────────────

340. Longest Substring with At Most K Distinct Character

159. Longest Substring with At Most Two Distinct Characters 的泛化版。

class Solution:
    def lengthOfLongestSubstringKDistinct(self, s: str, k: int) -> int:
        fast = 0
        slow = 0
        memo = defaultdict(int)
        res = 0
        while fast < len(s):
            char = s[fast]
            fast += 1

            memo[char] += 1

            while len(memo) > k:
                d = s[slow]
                slow += 1
                memo[d] -= 1
                if memo[d] == 0:
                    del memo[d]
            res = max(res, fast - slow)
        return res

--tags#Sliding Window
$ ls ./coding/ | grep -v 340-longest-substring-with-at-most-k-distinct-character
265. Paint House II256. Paint House143. Reorder List1762. Buildings With an Ocean View
← cd ../codingcd ~