算法---最长不重复子串

给定一个字符串,求其最长的没有重复字符的子串的长度

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
__title__ = ''
__author__ = 'thinkreed'
__mtime__ = '17/3/3'

"""


class Solution:
    def longest_substring(self, str):

        start = max_length = 0
        # 已出现过的字符字典, char -> index
        usedChar = {}

        for i in range(len(str)):
            # 如果出现重复,从当前的后一位开始计算
            if str[i] in usedChar:
                start = usedChar[str[i]] + 1

            # 最大长度计数,并将当前字符加入字典
            max_length = max(max_length, i - start + 1)
            usedChar[str[i]] = i

        return max_length


if __name__ == '__main__':
    print(Solution().longest_substring("pwwkew"))
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 最长回文子串——Manacher 算法 1. 问题定义 最长回文字符串问题:给定一个字符串,求它的最长回文子串长度...
    林大鹏阅读 7,760评论 0 6
  • 算法字符串系列的第四篇文章,计算给定字符串的最长无重复子串。 这篇文章主要介绍两种方法,一种是基于hash的思想,...
    zero_sr阅读 14,837评论 3 14
  • 1. 问题定义 最长不重复子串:一个字符串中最长的没有重复字符的子串。举个🌰 : abcabcbb 最长子串 a...
    林大鹏阅读 14,111评论 0 2
  • 面试算法代码知识梳理系列 面试算法知识梳理(1) - 排序算法面试算法知识梳理(2) - 字符串算法第一部分面试算...
    泽毛阅读 5,473评论 0 6
  • 在很早的时候,农村中经常有狼出没。孩子不小心就会被狼吃掉。就象鲁迅小说《祝福》中祥林嫂的阿毛一样。于是大人们就用狼...
    研悟阅读 4,179评论 0 1

友情链接更多精彩内容