码迷,mamicode.com
首页 > 编程语言 > 详细

最长非重复子串(python实现)

时间:2020-02-20 15:11:50      阅读:59      评论:0      收藏:0      [点我收藏+]

标签:dex   max   inpu   一个   应该   not   筛选   结束   app   

'''
取一个起始位置和一个结束位置,结束位置用于往活动字符串(列表)中放字符。
如果活动列表长度大于最长列表的长度,替换。
如果活动列表中存在该字符并且原字符串中的起始位置和结束位置对应的值相同,结束位置赋值给起始位置。
否则起始位置等于原字符串中该字符对应索引的下一个位置。
'''

b = 'abaaacddff'
# k = input()
# print(b.index(k))
max_string = []
ac_string = []
lis = list(b)
start = 0
end = 0
while end != len(b):
    if b[end] not in ac_string:
        ac_string.append(b[end])
        end +=1
    else:
        if lis[start] == lis[end]: #筛选出全是重复的例子:aaaaa这种
            start = end
        else:
            start = start + ac_string.index(b[end]) +1 #aaabb这种,当第二个b不能与a(最后一个a),则应该把start从第二个b开始
            end = start
        ac_string = []
    if len(max_string) < len(ac_string):
        max_string = ac_string

max_string = ''.join(max_string)
print(max_string)

最长非重复子串(python实现)

标签:dex   max   inpu   一个   应该   not   筛选   结束   app   

原文地址:https://www.cnblogs.com/michealjy/p/12335564.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!