手写算法:
链接: https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/
var lengthOfLongestSubstring = function(s) {// 哈希集合,记录每个字符是否出现过const occ = new Set();const n = s.length;// 右指针,初始值为 -1,相当于我们在字符串的左边界的左侧,还没有开始移动let rk = -1, ans = 0;for (let i = 0; i < n; ++i) {if (i != 0) {// 左指针向右移动一格,移除一个字符occ.delete(s.charAt(i - 1));}while (rk + 1 < n && !occ.has(s.charAt(rk + 1))) {// 不断地移动右指针occ.add(s.charAt(rk + 1));++rk;}// 第 i 到 rk 个字符是一个极长的无重复字符子串ans = Math.max(ans, rk - i + 1);}return ans;};
手写题:
手写vuex新版和老版
