查看: 2892| 回复: 1
跳转到指定楼层
上一主题 下一主题
收起左侧

[Leetcode] Longest Substring with At Most K Distinct Characters

全局:

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
Given a string s, find the length of the longest substring T that contains at most k distinct characters.


地里有木有大神刷到这个题?求一个Python的解法,如果能有讲解是最好的了,谢谢!

上一篇:study progress for the ctci 189
下一篇:谁有cc150 for dummy的excel解题思路附件?
推荐
红A 2017-9-4 14:25:28 | 只看该作者
全局:
这是我fb面到的一道题。不过我用java刷的。。。

class Solution(object):
    def lengthOfLongestSubstringKDistinct(self, s, k):
        d = collections.defaultdict(int)
        i, res = 0, 0
        for j in range(len(s)):
            d[s[j]] += 1
            # while have more than k, we keep removing from i
            while len(d)>k:
                d[s[i]] -= 1
                if d[s[i]] == 0:
                    del d[s[i]]
                i += 1
            res = max(res, j-i+1)
        return res
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表