前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >leetcode: 3. Longest Substring Without Repeating Characters

leetcode: 3. Longest Substring Without Repeating Characters

作者头像
JNingWei
发布2018-09-28 14:28:29
3020
发布2018-09-28 14:28:29
举报
文章被收录于专栏:JNing的专栏

Difficulty

Medium.

Problem

代码语言:javascript
复制
# Given a string, find the length of the longest substring without repeating characters.
#
# Examples:
#
# Given "abcabcbb", the answer is "abc", which the length is 3.
#
# Given "bbbbb", the answer is "b", with the length of 1.
#
# Given "pwwkew", the answer is "wke", with the length of 3. 
# Note that the answer must be a substring, "pwke" is a subsequence and not a substring.

AC

代码语言:javascript
复制
class Solution():
    def lengthOfLongestSubstring(self, s):
        longest, start, visited = 0, 0, [False for _ in range(256)]
        for ind, val in enumerate(s):
            if not visited[ord(val)]:
                visited[ord(val)] = True
                longest = max(longest, ind-start+1)
            else:
                while s[start] != val:
                    visited[ord(s[start])] = False
                    start += 1
                start += 1
        return longest


if __name__ == '__main__':
    assert Solution().lengthOfLongestSubstring('abcabcbb') == 3
    assert Solution().lengthOfLongestSubstring('bbbb') == 1
    assert Solution().lengthOfLongestSubstring('pwwkew') == 3
代码语言:javascript
复制
class Solution():
    def lengthOfLongestSubstring(self, s):
        longest = 0
        i, j = 0, 1
        while j < len(s):
            if len(''.join(list(set(s[i:j+1])))) == len(s[i:j+1]):
                if len(s[i:j+i]) > longest:
                    longest = len(s[i:j+1])
                j += 1
            else:
                i += 1
        return longest
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017年10月31日,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Difficulty
  • Problem
  • AC
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档