前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >BAT面试算法进阶(3)- 无重复字符的最长子串(滑动窗口法)

BAT面试算法进阶(3)- 无重复字符的最长子串(滑动窗口法)

作者头像
iOSSir
发布于 2023-03-19 03:56:41
发布于 2023-03-19 03:56:41
3410
举报

上篇文章分享的是暴力解决方法.暴力法非常简单,但是它的速度不够快!那么我们该如何去做优化了?

算法题

  • 题目

Given a string, find the length of the longest substring without repeating characters.

  • Example

  • 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
  • Note that the answer must be a substring, "pwke" is a subsequence and not a substring.

算法题解读

  • 题目大意:给定一个字符串,找出不含有重复字符的最长子串的长度
  • 解读Example

  • 给定"abcabcbb",没有重复字符的最长子串是"abc",那么长度就是3
  • 给定"bbbbb",最长子串就是"b",长度就是1
  • 给定pwwkew,最长子串就是"wke",长度为3,
  • ==注意,==必须是一个子串."pwke",是子序列,而不是子串

"滑动窗口法"优化解决

使用暴力法解决是非常简单,但是在暴力法中我们会反复检查一个子字符串是否含有重复的字符.但其实没有这个必要.

前导关键词介绍

  • HashSet HashSetJava中实现Set接口.由哈希表支持.它不保证Set的迭代顺序,但是它利用Hash的原理来确保元素的唯一性.在HashSet中,元素都存到HashMap键值对的key上面.而Value时有一个统一的Hash值.
  • HashSet的插入 当有新的值加入时,底层的HashMap会判断Key值是否存在,如果不存在则插入新值.同时这个插入的细节会按照HashMap插入细节.如果存在则不插入.
  • 滑动窗口 是指的是数组/字符串问题的常用抽象概念.窗口通常在数组/字符串中由开始和结束的索引定义的一系列元素的集合.即可[i,j)(左闭,右开).而滑动窗口是可以将2个边界向某一个方向"滑动"的窗口.例如,我们将[i,j)向右滑动1个元素,则它将变成[i+1,j+1)(左闭,右开);

思路

如果从索引i到j-1之间的子字符串S[ij]已经被检查为没有重复字符.那则只需要检查s[j]对应的字符是否存在于子字符串s[ij];

由于在C语言中是没有集合这一个概念的.所以我们使用java来实现.我们可以通过HashSet作为活动窗口.那我们只需要用O(1)的时间来完成对字符是否在当前子字符串的检查.

我们使用HashSet将字符存储在当前窗口[i,j),最初i=j .然后我们向右侧滑动索引j,如果它不在HashSet中,则我们会继续滑动j.直到s[j]已经存在于HashSet中,此时,我们就已经找到的没有重复字符的最长子串将会以索引i开头.如果我们将所有的i,都做如此操作即可得到结果.

实现

Java Code

复杂度分析

  • 时间复杂度: o(2n) = o(n);在最糟糕的情况下,每个字符顶多被i,j访问2次.
  • 空间复杂度: o(min(m,n)).窗口滑动法需要O(K)的空间,K指的是集合大小.而集合的大小取决于字符串n的大小以及字符串集的大小.

算法面试系列文章:

BAT面试算法进阶(1)--两数之和 BAT面试算法进阶(2)- 无重复字符的最长子串(暴力法) BAT面试算法进阶(4)- 无重复字符的最长子串(滑动法优化+ASCII码法) BAT面试算法进阶(5)- BAT面试算法进阶(5)- 最长回文子串(方法一) BAT面试算法进阶(6)- BAT面试算法进阶(6)-最长回文子串(方法二) BAT面试算法进阶(7)- 反转整数 BAT面试算法进阶(8)- 删除排序数组中的重复项 BAT面试算法进阶(9)- 三维形体投影面积 BAT面试算法进阶(10)- 最长的斐波那契子序列的长度(暴力法) BAT面试算法进阶(11)- 最长的斐波那契子序列的长度(动态规划法) BAT面试算法进阶(12)- 环形链表(哈希表法)

还不赶紧

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-02-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Python课后小剧场 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
BAT面试算法进阶(2)- 无重复字符的最长子串(暴力法)
Given a string, find the length of the longest substring without repeating characters.
iOSSir
2023/03/19
2800
BAT面试算法进阶(2)- 无重复字符的最长子串(暴力法)
BAT面试算法进阶(4)- 无重复字符的最长子串(滑动法优化+ASCII码法)
Given a string, find the length of the longest substring without repeating characters.
iOSSir
2023/03/19
2800
BAT面试算法进阶(4)- 无重复字符的最长子串(滑动法优化+ASCII码法)
BAT面试算法进阶(4)-无重复字符的最长子串
Given a string, find the length of the longest substring without repeating characters.
CC老师
2018/08/22
7510
BAT面试算法进阶(4)-无重复字符的最长子串
LeetCode3.滑动窗口: 双指针法(Kotlin语言)-无重复字符的最长子串
输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
一个会写诗的程序员
2020/04/24
7240
BAT面试算法进阶(3)-无重复字符的最长子串
Given a string, find the length of the longest substring without repeating characters.
CC老师
2018/08/22
3470
BAT面试算法进阶(3)-无重复字符的最长子串
BAT面试算法进阶(4)- 无重复字符的最长子串(滑动法优化+ASCII码法)
Given a string, find the length of the longest substring without repeating characters.
CC老师
2023/03/23
2650
BAT面试算法进阶(4)- 无重复字符的最长子串(滑动法优化+ASCII码法)
BAT面试算法进阶(2)- 无重复字符的最长子串(暴力法)
Given a string, find the length of the longest substring without repeating characters.
CC老师
2023/03/23
1960
BAT面试算法进阶(2)- 无重复字符的最长子串(暴力法)
BAT面试算法进阶(5)- 最长回文子串(方法一)
Given a string s, find the longest palindromic substring in s. You may assume that the maximum length of s is 1000.
iOSSir
2023/03/19
2420
BAT面试算法进阶(5)- 最长回文子串(方法一)
BAT面试算法进阶(6)- 最长回文子串(方法二)
Given a string s, find the longest palindromic substring in s. You may assume that the maximum length of s is 1000.
iOSSir
2023/03/19
1720
BAT面试算法进阶(6)- 最长回文子串(方法二)
LeetCode 03无重复字符的最长子串(滑动窗口)
本题选择的思路是滑动窗口,滑动窗口,就是用一个区间从左往右,右侧先进行试探,找到区间无重复最大值,当有重复时左侧再往右侧移动一直到没重复,然后重复进行。在整个过程中找到最大的那个空间返回即可。
bigsai
2020/08/13
6890
LeetCode 03无重复字符的最长子串(滑动窗口)
《画解算法》3. 无重复字符的最长子串【python3丨简单】
输入: s = "abcabcbb" 输出: 3  解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。 示例 2:
不吃西红柿
2022/09/19
5320
《画解算法》3. 无重复字符的最长子串【python3丨简单】
【LeetCode02】找出不含重复字符的 最长子串 的长度
这道题,一开始最直接的想法就是暴力法,直接穷举所有的子串,然后选择无重复的子串中最长的那个。
Sam Gor
2019/07/08
1.6K1
【滑动窗口】无重复字符的最长子串
​ 首先我们得做个小优化,因为我们在遍历字符串的时候,是根据是否出现了重复字符来判断是否符合要求,那么我们可以使用 哈希表,将遍历过的字符进行映射!
利刃大大
2025/05/10
580
【滑动窗口】无重复字符的最长子串
BAT面试算法进阶(7)- 反转整数
假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−2^31, 2^31 − 1]。根据这个假设,如果反转后的整数溢出,则返回 0。
iOSSir
2023/03/19
2370
BAT面试算法进阶(7)- 反转整数
BAT面试算法进阶(8)- 删除排序数组中的重复项
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
iOSSir
2023/03/19
2930
BAT面试算法进阶(8)- 删除排序数组中的重复项
无重复字符的最长子串(LeetCode 3)
我们可以遍历字符串的所有字符,计算每个字符为起点的不含有重复字符的字串长度,记录到全局变量。
恋喵大鲤鱼
2023/12/09
3410
图解LeetCode——3. 无重复字符的最长子串(难度:中等)
通过两层for循环可以实现暴力破解寻找无重复字符串,最外层i循环,作为每次生成子字符串的头节点;第二层j循环,每次从i位置开始,拼装子字符串。最后选择长度最长的作为返回值。具体逻辑如下图所示:
爪哇缪斯
2023/05/10
1910
图解LeetCode——3. 无重复字符的最长子串(难度:中等)
【剑指offer:最长不含重复字符的子字符串】滑动窗口(双指针)+优化改进思路
题目描述:请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。
心谭博客
2020/04/21
4700
无重复字符的最长子串
难度:中等 来源:3. 无重复字符的最长子串 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 输入: s = "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。 示例 2: 输入: s = "bbbbb" 输出: 1 解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。 示例 3: 输入: s = "pwwkew" 输出: 3 解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。 请注意,
用户4456933
2021/06/01
5240
Leetcode 3. 无重复字符的最长子串 (滑动窗口+HashMap)
输入: “abcabcbb” 输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。 示例 2:
glm233
2020/09/28
2690
推荐阅读
相关推荐
BAT面试算法进阶(2)- 无重复字符的最长子串(暴力法)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档