386. 最多有k个不同字符的最长子字符串

描述

给定一个字符串,找到最多有 k 个不同字符的最长子字符串。

样例

例如,给定 s ="eceba", k = 3, T 是"eceb",长度为4.

挑战

O(n), n 是所给字符串的长度

思路

仍旧是前向型指针,i j 交替前行,对于当前 i 当 j 满足条件时跳出 j 无需再向前, i 向前移动一位,继续寻找满足条件的 j

代码

public class Solution {
    /**
     * @param s : A string
     * @return : The length of the longest substring 
     *           that contains at most k distinct characters.
     */
    public int lengthOfLongestSubstringKDistinct(String s, int k) {
        int maxLen = 0;

        // Key: letter; value: the number of occurrences.
        Map<Character, Integer> map = new HashMap<Character, Integer>();
        int i, j = 0;
        char c;
        for (i = 0; i < s.length(); i++) {
            // j 在向前移动时,统计 j 所对应的字母出现的次数,当hash表中有 k 个不同字母时, j 就无需向前移动了
            while (j < s.length()) {
                c = s.charAt(j);
                if (map.containsKey(c)) {
                    map.put(c, map.get(c) + 1);
                } else {
                    if (map.size() == k) {
                        break;
                    }
                    map.put(c, 1);
                }
                j++;
            }
      
            maxLen = Math.max(maxLen, j - i);
            // i 往前移动一位,在hash表中移除当前i对应的字母一次
            c = s.charAt(i);
            if (map.containsKey(c)){
                int count = map.get(c);
                if (count > 1) {
                    map.put(c, count - 1);
                } else {
                    map.remove(c);
                }
            }
        }
        return maxLen; 
    }  
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容