前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LintCode 386. 最多有k个不同字符的最长子字符串(双指针)

LintCode 386. 最多有k个不同字符的最长子字符串(双指针)

作者头像
Michael阿明
发布2020-07-13 15:59:04
4380
发布2020-07-13 15:59:04
举报
文章被收录于专栏:Michael阿明学习之路

1. 题目

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

代码语言:javascript
复制
样例 1:
输入: S = "eceba" 并且 k = 3
输出: 4
解释: T = "eceb"

样例 2:
输入: S = "WORLD" 并且 k = 4
输出: 4
解释: T = "WORL" 或 "ORLD"

挑战
O(n) 时间复杂度

2. 解题

代码语言:javascript
复制
class Solution {
public:
    int lengthOfLongestSubstringKDistinct(string &s, int k) {
        // write your code here
        int i = 0, j = 0, MAX = 0, n = s.size(), count = 0;
        unordered_map<char,int> m;
        char ch;
        for( ; j < n; j++) 
        {
            ch = s[j];
            if (m[ch] == 0) //右端点有新的字符
                count++;
            m[ch]++;
            if(count > k) //字符种类超了
            {
                ch = s[i++];
                m[ch]--;
                if(m[ch] == 0) 
                    count--;//如果为0,种类减少
            }
            MAX = j-i+1;//MAX只增不减,是最后的答案
        }
        return MAX;
    }
};

100% 数据通过测试 总耗时 302 ms 您的提交打败了 41.40% 的提交!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/03/06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目
  • 2. 解题
相关产品与服务
腾讯云服务器利旧
云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档