[3]无重复字符的最长子串
给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: s = "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:
输入: s = "bbbbb" 输出: 1 解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:
输入: s = "pwwkew" 输出: 3 解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。 请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
提示:
- 0 <= s.length <= 5 * 104
- s 由英文字母、数字、符号和空格组成
Related Topics
- 哈希表
- 字符串
- 滑动窗口
解题思路
对字符串进行遍历,遍历的时候往新的数组中塞入该元素,如果遇到重复的元素,就把前面的所有数据进行删除,然后继续塞入,直道遍历完毕
代码
//leetcode submit region begin(Prohibit modification and deletion)
/**
* @param {string} s
* @return {number}
*/
var lengthOfLongestSubstring = function(s) {
let max = 0;
let sList = [];
for (let i = 0; i < s.length; i++) {
if (sList.indexOf(s[i]) === -1) {
sList.push(s[i]);
} else {
sList.splice(0, sList.indexOf(s[i]) + 1);
sList.push(s[i]);
}
max = Math.max(max, sList.length);
}
return max;
};
console.log(lengthOfLongestSubstring('abbcd'))
//leetcode submit region end(Prohibit modification and deletion)
截图