news 2026/6/10 17:37:11

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/6/10 11:49:38

AutoGLM搭建新手方案不装大模型也能跑的手机AI助手

如果你在网上搜过AutoGLM搭建&#xff0c;大概率会看到两条路线&#xff1a;一条是自己把模型服务跑起来&#xff0c;另一条是找现成API。理论上第一条更自由&#xff0c;但现实是门槛很高&#xff1a;动辄要下载二十GB左右的模型文件&#xff0c;还经常被建议准备24GB以上显存…

作者头像 李华
网站建设 2026/6/9 17:45:51

终极指南:如何用unrolled/render简化Go Web开发

终极指南&#xff1a;如何用unrolled/render简化Go Web开发 【免费下载链接】render Go package for easily rendering JSON, XML, binary data, and HTML templates responses. 项目地址: https://gitcode.com/gh_mirrors/ren/render 在Go语言Web开发中&#xff0c;高效…

作者头像 李华
网站建设 2026/6/9 20:50:14

Python新手必看:轻松理解NoneType.shape错误

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个交互式学习模块&#xff0c;通过可视化方式解释NoneType和shape概念&#xff1a;1. 使用流程图展示变量生命周期 2. 包含可操作的代码沙盒 3. 渐进式练习&#xff08;从基础…

作者头像 李华
网站建设 2026/6/10 13:35:36

Dolphin模拟器终极指南:3步打造完美GameCube游戏体验

还记得第一次在GameCube上玩《塞尔达传说&#xff1a;风之杖》的激动吗&#xff1f;现在&#xff0c;通过Dolphin模拟器&#xff0c;你可以在现代设备上重温这些经典。本文将带你从零开始&#xff0c;掌握让游戏流畅运行的完整方法体系。 【免费下载链接】sudachi Sudachi is a…

作者头像 李华
网站建设 2026/6/10 13:36:38

Windows平台EMQX性能优化:传统与AI辅助方案对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 编写一个性能测试套件&#xff0c;比较手动配置和AI优化配置下EMQX在Windows上的表现。包括并发连接数、消息吞吐量、延迟等指标。生成可视化对比图表和分析报告&#xff0c;提出优…

作者头像 李华
网站建设 2026/6/9 17:03:49

GloVe词向量终极实战指南:30分钟构建专业级文本语义分析系统

还在为NLP项目中的词语语义表示而苦恼&#xff1f;想要快速构建一个能够理解文本深层含义的智能系统&#xff1f;GloVe词向量技术正是你需要的终极解决方案。本文将带你从零开始&#xff0c;用30分钟构建完整的文本语义分析系统&#xff0c;无需深厚技术背景&#xff0c;只需跟…

作者头像 李华