当前位置: 首页 > wzjs >正文

黄江网站仿做长春网络推荐

黄江网站仿做,长春网络推荐,微信商城怎么开发,怎么更改网站首页图片尺寸LeetCode LCR 016. 无重复字符的最长子串 滑动窗口法解「无重复字符的最长子串」 问题描述 给定一个字符串 s,找出其中不含有重复字符的 最长连续子字符串 的长度。 示例 输入:s "abcabcbb" 输出:3(最长子串为 &qu…

LeetCode LCR 016. 无重复字符的最长子串


滑动窗口法解「无重复字符的最长子串」

问题描述

给定一个字符串 s,找出其中不含有重复字符的 最长连续子字符串 的长度。

示例

输入:s = "abcabcbb"
输出:3(最长子串为 "abc"


解题思路

滑动窗口法(双指针)

  1. 窗口定义:用左右指针 leftright 表示当前窗口的左右边界,窗口内字符不重复。

  2. 核心操作:
    • 扩展右边界:右指针不断右移,直到遇到重复字符。

    • 收缩左边界:一旦发现重复,左指针右移一位,移除原左边界字符。

  3. 去重机制:通过哈希集合 Set 实时记录窗口内的字符,确保窗口的唯一性。


算法流程

步骤详解

  1. 初始化:
    • 左指针 left = 0,右指针 right = 0

    • 哈希集合 Set 存储窗口字符

    • 结果变量 res 记录最大长度

  2. 滑动窗口扩展:

    for (int left = 0; left < s.length(); left++) {// 右指针扩展至出现重复或越界while (right < s.length() && !set.contains(s.charAt(right))) {set.add(s.charAt(right));right++;}// 更新最大长度res = Math.max(res, right - left);// 左指针右移一位,移除原左边界字符set.remove(s.charAt(left));
    }
    
  3. 动态调整:
    • 每次左指针右移后,右指针从当前位置继续扩展,无需回溯。


复杂度分析

• 时间复杂度:O(n),左右指针各遍历一次字符串。

• 空间复杂度:O(1),字符集大小固定(ASCII 最多 128 种字符)。


代码实现
public static int lengthOfLongestSubstring(String s) {int right = 0;      // 窗口右边界int res = 0;        // 最长子串长度Set<Character> set = new HashSet<>();for (int left = 0; left < s.length(); left++) {// 右指针扩展至出现重复或越界while (right < s.length() && !set.contains(s.charAt(right))) {set.add(s.charAt(right));right++;}// 更新最大长度res = Math.max(res, right - left);// 左指针右移一位,移除原左边界字符set.remove(s.charAt(left));}return res;
}

力扣通过截图

在这里插入图片描述


示例解析

示例 1:s = "abcabcbb"

  1. 初始状态:left=0, right=0
    • 窗口扩展至 right=3(字符 a,b,c),此时 res=3

  2. 左指针右移:left=1,移除 a
    • 窗口扩展至 right=4(加入 a 失败,窗口变为 b,c,ares=3

  3. 循环结束:最终 res=3


关键点说明
为何时间复杂度是 O(n)?
• 每个字符最多被左右指针各访问一次,无重复操作。

为何用 Set 而不用 Map
Set 直接检查是否存在重复,无需记录索引,节省空间。

如何处理中间重复字符?
• 左指针每次仅移动一位,逐步缩小窗口,确保窗口内始终无重复。


拓展思考

优化版本(跳跃式收缩)
若记录字符的最新位置,左指针可跳跃式移动:

Map<Character, Integer> map = new HashMap<>();
int left = 0;
for (int right = 0; right < s.length(); right++) {if (map.containsKey(s.charAt(right))) {left = Math.max(left, map.get(s.charAt(right)) + 1);}map.put(s.charAt(right), right);res = Math.max(res, right - left + 1);
}

• 优势:减少左指针移动次数,提升效率。

力扣通过截图

在这里插入图片描述


通过滑动窗口法,我们高效地解决了子串查重问题,平衡了时间与空间复杂度。此方法在字符串处理中具有广泛的应用场景。


文章转载自:

http://OMozfscO.mggwr.cn
http://6rKDUF0p.mggwr.cn
http://71n1Cgne.mggwr.cn
http://sJjbcAyI.mggwr.cn
http://ezXa2kRa.mggwr.cn
http://zeAW1c17.mggwr.cn
http://kL0HMqMH.mggwr.cn
http://RUspsWIC.mggwr.cn
http://U5atplPJ.mggwr.cn
http://RpvZVpdO.mggwr.cn
http://cXb6WdJp.mggwr.cn
http://VIFZeQno.mggwr.cn
http://12PrnI2x.mggwr.cn
http://0RbKsmIM.mggwr.cn
http://t389KPON.mggwr.cn
http://zEBKCpuO.mggwr.cn
http://0uDYpXcl.mggwr.cn
http://aqVrQEjD.mggwr.cn
http://QpiKy8Ib.mggwr.cn
http://wGa7VT7w.mggwr.cn
http://oWKDLGDc.mggwr.cn
http://PPUK8mM7.mggwr.cn
http://FdJZJbyp.mggwr.cn
http://rZq1AJpB.mggwr.cn
http://jxvdk2px.mggwr.cn
http://6jGThcR6.mggwr.cn
http://OF2aVVzz.mggwr.cn
http://dtdgIZwG.mggwr.cn
http://FTvG1SQk.mggwr.cn
http://TzeW5Cqz.mggwr.cn
http://www.dtcms.com/wzjs/620164.html

相关文章:

  • 海南网站制做的公司科技网站设计公司有哪些
  • 自己做自己的私人网站交易平台网站开发教程百度云
  • 百度怎么做自己网站母婴用品网站建设规划
  • 企业网站的推广方式创意网络
  • 银联支付网站建设php商城
  • 伊宁市住房与城乡建设局网站wordpress电商网站
  • 搜索网站开发背景做详情页比较好的网站
  • 建一个团购网站需要多少钱网站 语言切换怎么做
  • 好友介绍网站怎么做怎么制作网站栏目页主页
  • 陕西公司网站建设网站开发 营业执照
  • 北京做网站公司哪家强营销网页设计
  • 网站第一步建立做第三方网站注意什么意思
  • 广州网站设计费用服装设计公司图片
  • 最方便在线网站开发南昌网优化seo公司
  • 旅游网站怎么建设wordpress添加社交媒体链接
  • 手机开发者网站企业网站管理系统 才能湖南岚鸿
  • 工地招聘网站必应搜索推广
  • 网站管理制度建设做视频自媒体要投稿几个网站
  • 深圳市建设交易中心官网seo经验
  • 高端网站定制的方法网站如何增加流量
  • 网站教程网为啥都用wordpress
  • 网站开发自学网风景网页设计图片
  • 什么软件可以找做网站的云南人
  • 自已建外贸网站深圳网站设计营销型
  • 科技建筑公司网站外贸自建站费用
  • 贵阳网站建设服务公司百度关键词排行榜
  • 网站被抓取简述网站建设的五类成员
  • html5网站链接标签标书制作员工作内容
  • 泗洪网站手机怎么样自己做网站
  • 面包机做面包网站网站开发用什么字体