[LeetCode: No.3]
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.
解法一
粗暴的想法是利用循环嵌套对所有情况进行遍历。大体的思路是:第一层循环从字符串的最左侧到左右侧第二个,然后第二层循环从第一层紧跟着的一个到最后的字符串,之后比较长度得到最大长度的子字符串
1 | def lengthOfLongestSubstring(self, s): |
这种解法虽然可以通过,但是效率很低,时间会很长
解法二
1 | def lengthOfLongestSubstring(self, s): |
接下来举例说明下为什么【i - indexDict[s[i]] - 1】代表了当前找到子字符串的长度。 比如字符串’abcdadd’,代码运行过程中一直迭代到i=3【对应字符d】时,都不满足s[i] in indexDict ,不执行条件语句,而是currMax依次加一,并且将字符信息以{s[i]:i}的形式存放在字典中。当继续迭代i=4时,进入条件语句,这里主要解释【i - indexDict[s[i]] - 1】,检测到了重复字符’a’,之前该字符出现位置为i=0处即【indexDict[s[i]] =0】这时候当前检测到的无重复字符子串为’abcd’,长度为【4-indexDict[s[i]] -1 = 3】。其他同此例。