本文共 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),因为我们用数组来存储窗口中的字符。
举例来说:
总的来说,这种滑动窗口法既高效又简单,能够快速找到不含重复字符的最长子字符串。
转载地址:http://pcxpz.baihongyu.com/