题目
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
示例
输入: "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
解题思路
1 .滑动窗口
#python
class Solution(object):
def lengthOfLongestSubstring(self, s):
"""
:type s: str
:rtype: int
"""
ans = 0
s_t = ""
for i in s:
if i in s_t:
s_t=s_t.split(i)[-1]
s_t += i
ans = max(ans,len(s_t))
return ans
思想简单,效率一般
2 桶排序?
//c
int lengthOfLongestSubstring(char * s){
int start = 0, end = 0, maxlen = 0;
char map[512] = {0};
map[(int)*(s+start)] = 1;
while( *(s+end) != 0 )
{
maxlen = maxlen>(end-start+1)?maxlen:(end-start+1);
++end;
while( 0 != map[ (int)*(s+end) ] )//将要加入的新元素与map内元素冲突,然后循环自增start=end
{
map[ (int)*(s+start) ] = 0;
++start;
}
map[(int)*(s+end)] = 1;
}
return maxlen;
}
评论中看到的,时间复杂度超过100%的人。
网友评论