news 2026/5/9 23:47:49

LeetCode Hot 100:无重复的最长子串解题思路详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode Hot 100:无重复的最长子串解题思路详解

LeetCode Hot 100:无重复的最长子串解题思路详解

最近在刷 LeetCode Hot 100 题目时,遇到了一道经典题目——无重复的最长子串(Longest Substring Without Repeating Characters)。虽然题目名称和你提供的代码似乎有些出入(你给出的代码更像是「移动零」问题),但本文将围绕「无重复的最长子串」进行详细讲解,并指出可能的误解。


📌 题目描述

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

示例:

输入: s = "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

❗ 注意:你提供的代码对应的是「移动零」问题

你贴出的 Java 代码实际上是 LeetCode 第 283 题「移动零」 的典型双指针解法,而不是「无重复的最长子串」的解法。我们先来澄清这一点:

public void move(int[] nums) { int left = 0, right = 0; int n = nums.length; while (right < n) { if (nums[right] != 0) { swap(nums, left, right); left++; } right++; } } public void swap(int[] nums, int left, int right) { int tmp = nums[left]; nums[left] = nums[right]; nums[right] = tmp; }

这段代码的作用是将数组中的所有非零元素移到前面,零移到后面,保持相对顺序。它使用了双指针技巧left指向下一个非零元素应放置的位置,right遍历整个数组。


✅ 正确题目:无重复的最长子串(LeetCode #3)

🔍 解题思路:滑动窗口 + 哈希表

我们要解决的问题是:在一个字符串中找没有重复字符的最长子串

我们可以使用滑动窗口(Sliding Window)技巧配合HashSet来记录当前窗口内的字符。

  • 使用两个指针leftright表示窗口边界。
  • right不断向右扩展,遇到新字符时判断是否已在窗口中。
  • 如果已存在,则移动left直到该字符不再重复。
  • 维护一个最大长度变量maxLen记录历史最长值。
✅ Java 实现
import java.util.HashSet; public class Solution { public int lengthOfLongestSubstring(String s) { int left = 0, right = 0; int maxLen = 0; HashSet<Character> seen = new HashSet<>(); while (right < s.length()) { char c = s.charAt(right); while (seen.contains(c)) { seen.remove(s.charAt(left)); left++; } seen.add(c); maxLen = Math.max(maxLen, right - left + 1); right++; } return maxLen; } }
⏱️ 时间复杂度
  • 时间复杂度:O(n),每个字符最多被访问两次(left 和 right 各一次)
  • 空间复杂度:O(min(m,n)),哈希集大小取决于字符集(如 ASCII)

💡 总结

| 问题 | 方法 | |------|------| | 移动零 | 双指针 + 交换 | | 无重复的最长子串 | 滑动窗口 + HashSet |

⚠️ 刷题时一定要注意题目与代码的一致性!混淆题号或逻辑可能导致理解偏差。


📌建议学习路径:

  1. 掌握双指针基础(如移动零、删除重复项)
  2. 进阶学习滑动窗口模型(适用于子串/子数组问题)
  3. 结合哈希表、队列等数据结构提升效率

如果你也在刷 LeetCode,欢迎关注我一起打卡成长!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/9 15:49:51

WUB音效在电子音乐中的5种实战应用技巧

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个电子音乐制作教学应用&#xff0c;重点展示WUB音效的制作和应用。包含&#xff1a;1) WUB音效生成器 2) 5种典型应用场景演示 3) 参数调节教学模块 4) 与主流DAW的集成指导…

作者头像 李华
网站建设 2026/5/1 6:25:06

效率对比:传统调试 vs AI辅助解决数组错误

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个Jupyter Notebook对比实验&#xff1a;1) 传统方法部分&#xff1a;人工编写5种常见的会导致setting an array element with a sequence错误的代码&#xff0c;记录调试时间…

作者头像 李华
网站建设 2026/5/1 6:25:30

用Fiddler+Postman快速验证API接口设计

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 构建一个API快速验证工具链&#xff0c;实现&#xff1a;1.Fiddler捕获的请求自动导入Postman&#xff1b;2.智能生成API测试用例&#xff1b;3.一键导出Markdown格式文档&#xff…

作者头像 李华
网站建设 2026/5/9 6:22:54

传统TLS升级 vs AI辅助升级:效率提升300%的秘诀

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 构建一个效率对比工具&#xff0c;左侧展示传统TLS升级需要的人工步骤和时间估算&#xff0c;右侧展示AI自动化解决方案的流程。要求包含&#xff1a;1) 配置检查&#xff1b;2) 修…

作者头像 李华
网站建设 2026/5/6 5:00:55

3分钟搞定SSH主机认证:告别重复确认

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个极简命令行工具ssh-quicktrust&#xff0c;功能&#xff1a;1. 自动接受常见代码托管平台&#xff08;GitHub/GitLab等&#xff09;的主机密钥&#xff1b;2. 支持批量处理…

作者头像 李华
网站建设 2026/5/6 6:15:52

24小时开发:Typora激活状态检测工具原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个Typora激活状态检测工具原型&#xff0c;要求&#xff1a;1. 自动检测注册表信息 2. 验证许可证有效性 3. 可视化展示结果 4. 支持导出检测报告 5. 异常情况预警。使用InsC…

作者头像 李华