博客
关于我
剑指 Offer 48. 最长不含重复字符的子字符串(JS实现)
阅读量:564 次
发布时间:2019-03-09

本文共 817 字,大约阅读时间需要 2 分钟。

剑指 Offer 48. 最长不含重复字符的子字符串

在做这个问题的时候,我想到了一种高效的方法——滑动窗口法。这种方法通过维护一个窗口来记录不含重复字符的子字符串,最终找到其中最长的一段。

具体来说,我们用数组 str 来临时存储最长长度不重复字符串,并用 maxLen 记录最大长度。每当遇到一个重复字符时,我们清空 str 并从下个字符开始重新滑动窗口。这样,每个字符只在窗口中出现一次,保证窗口内没有重复字符。

代码的逻辑是这样的:

var lengthOfLongestSubstring = function(s) {    let str = [], maxLen = 0;    for (let i = 0; i < s.length; i++) {        let index = str.indexOf(s[i]);        if (index != -1) {            // 移除重复字符之前的所有字符            str.splice(0, index + 1);        }        // 插入当前字符        str.push(s[i]);        // 更新最大长度        if (str.length > maxLen) {            maxLen = str.length;        }    }    return maxLen;};

这个方法的时间复杂度是 O(n),因为每个字符只会被处理一次。空间复杂度是 O(n),因为我们用数组来存储窗口中的字符。

举例来说:

  • 对于字符串 "dvdf",输出应该是 2。
  • 对于字符串 "abccbae",输出应该是 3。
  • 对于字符串 "ddwaglaslmdajga",输出应该是 12。

总的来说,这种滑动窗口法既高效又简单,能够快速找到不含重复字符的最长子字符串。

转载地址:http://pcxpz.baihongyu.com/

你可能感兴趣的文章
Objective-C实现all permutations所有排列算法(附完整源码)
查看>>
Objective-C实现all subsequences所有子序列算法(附完整源码)
查看>>
Objective-C实现AlphaNumericalSort字母数字排序算法(附完整源码)
查看>>
Objective-C实现alternate disjoint set不相交集算法(附完整源码)
查看>>
Objective-C实现alternative list arrange备选列表排列算法(附完整源码)
查看>>
Objective-C实现An Armstrong number阿姆斯特朗数算法(附完整源码)
查看>>
Objective-C实现anagrams字谜算法(附完整源码)
查看>>
Objective-C实现ApproximationMonteCarlo蒙特卡洛方法计算pi值算法 (附完整源码)
查看>>
Objective-C实现area under curve曲线下面积算法(附完整源码)
查看>>
Objective-C实现arithmetic算术算法(附完整源码)
查看>>
Objective-C实现armstrong numbers阿姆斯壮数算法(附完整源码)
查看>>
Objective-C实现articulation-points(关键点)(割点)算法(附完整源码)
查看>>
Objective-C实现atoi函数功能(附完整源码)
查看>>
Objective-C实现average absolute deviation平均绝对偏差算法(附完整源码)
查看>>
Objective-C实现average mean平均数算法(附完整源码)
查看>>
Objective-C实现average median平均中位数算法(附完整源码)
查看>>
Objective-C实现average mode平均模式算法(附完整源码)
查看>>
Objective-C实现avl 树算法(附完整源码)
查看>>
Objective-C实现AvlTree树算法(附完整源码)
查看>>
Objective-C实现backtracking Jump Game回溯跳跃游戏算法(附完整源码)
查看>>