牛客题解 | 最长无重复子数组

news/2025/2/21 9:54:16/文章来源:https://www.cnblogs.com/wc529065/p/18728446

题目

题目链接

题目主要信息:
  • 题目给定一个数组,要找到其中最长的无重复的子数组的长度
  • 子数组必须是数组中连续的一段
举一反三:

学习完本题的思路你可以解决如下题目:

BM90. 最小覆盖子串

方法:滑动窗口(推荐使用)

知识点1:滑动窗口

滑动窗口是指在数组、字符串、链表等线性结构上的一段,类似一个窗口,而这个窗口可以依次在上述线性结构上从头到尾滑动,且窗口的首尾可以收缩。我们在处理滑动窗口的时候,常用双指针来解决,左指针维护窗口左界,右指针维护窗口右界,二者同方向不同速率移动维持窗口。

知识点2:哈希表

哈希表是一种根据关键码(key)直接访问值(value)的一种数据结构。而这种直接访问意味着只要知道key就能在\(O(1)\)时间内得到value,因此哈希表常用来统计频率、快速检验某个元素是否出现过等。

思路:

既然要找一段连续子数组的内不重复的长度,我们可以使用滑动窗口,保证窗口内都是不重复的,然后窗口右界不断向右滑,如果窗口内出现了重复数组,说明新加入的元素与之前的重复了,只需要窗口左界也向右收缩就可以保证窗口内都是不重复的。

而保证窗口内的元素不重复,我们可以使用根据key值快速访问的哈希表,key值为窗口内的元素,value为其出现次数,只要新加入窗口的元素出现次数不为1,就是重复。

while(mp.get(arr[right]) > 1) //窗口左移,同时减去该数字的出现次数mp.put(arr[left],mp.get(arr[left++])-1); 

具体做法:

  • step 1:构建一个哈希表,用于统计数组元素出现的次数。
  • step 2:窗口左右界都从数组首部开始,每次窗口优先右移右界,并统计进入窗口的元素的出现频率。
  • step 3:一旦右界元素出现频率大于1,就需要右移左界直到窗口内不再重复,将左边的元素移除窗口的时候同时需要将它在哈希表中的频率减1,保证哈希表中的频率都是窗口内的频率。
  • step 4:每轮循环,维护窗口长度最大值。

图示:

alt

Java代码实现:

import java.util.*;
public class Solution {public int maxLength (int[] arr) {//哈希表记录窗口内非重复的数字HashMap<Integer, Integer> mp = new HashMap<>(); int res = 0;//设置窗口左右边界for(int left = 0, right = 0; right < arr.length; right++){ //窗口右移进入哈希表统计出现次数if(mp.containsKey(arr[right]))mp.put(arr[right],mp.get(arr[right])+1); elsemp.put(arr[right],1);//出现次数大于1,则窗口内有重复while(mp.get(arr[right]) > 1) //窗口左移,同时减去该数字的出现次数mp.put(arr[left],mp.get(arr[left++])-1); //维护子数组长度最大值res = Math.max(res, right - left + 1); }return res;}
}

C++代码实现:

class Solution {
public:int maxLength(vector<int>& arr) {//哈希表记录窗口内非重复的数字unordered_map<int, int> mp; int res = 0;//设置窗口左右边界for(int left = 0, right = 0; right < arr.size(); right++){ //窗口右移进入哈希表统计出现次数mp[arr[right]]++; //出现次数大于1,则窗口内有重复while(mp[arr[right]] > 1) //窗口左移,同时减去该数字的出现次数mp[arr[left++]]--; //维护子数组长度最大值res = max(res, right - left + 1); }return res;}
};

Python实现代码:

class Solution:def maxLength(self , arr: List[int]) -> int:#哈希表记录窗口内非重复的数字mp = dict() res = 0left = 0#设置窗口左右边界for right in range(len(arr)): if arr[right] in mp:#窗口右移进入哈希表统计出现次数mp[arr[right]] += 1 else:mp[arr[right]] = 1#出现次数大于1,则窗口内有重复while mp[arr[right]] > 1: #窗口左移,同时减去该数字的出现次数mp[arr[left]] -=1 left += 1#维护子数组长度最大值res = max(res, right - left + 1) return res

复杂度分析:

  • 时间复杂度:\(O(n)\),外循环窗口右界从数组首右移到数组尾,内循环窗口左界同样如此,因此复杂度为\(O(n+n)=O(n)\)
  • 空间复杂度:\(O(n)\),最坏情况下整个数组都是不重复的,哈希表长度就为数组长度\(n\)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/887480.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

牛客题解 | 最长的括号子串

牛客输入输出题单题解题目 题目链接 题目主要信息:一个长度为\(n\)的仅包含左右括号的字符串 计算最长的格式正确的括号子串的长度举一反三: 学习完本题的思路你可以解决如下题目: BM65 最长公共子序列(二) BM66.最长公共子串 BM71.最长上升子序列(一) BM73 最长回文子串 BM…

牛客题解 | 最长公共前缀

牛客输入输出题单题解题目 题目链接 题目主要信息:给定一个字符串数组,其中有n个字符串,求所有字符串的最长公共前缀 公共前缀是指所有字符串都共有的前面部分的子串,从第一个字符开始举一反三: 学会了本题的思路,你将可以解决类似的字符串问题: BM83. 字符串变形 BM85. …

牛客题解 | 旋转数组

牛客输入输出题单题解题目 题目链接 题目主要信息:一个长度为\(n\)的数组,将数组整体循环右移\(m\)个位置(\(m\)可能大于\(n\)) 循环右移即最后\(m\)个元素放在数组最前面,前\(n-m\)个元素依次后移 不能使用额外的数组空间举一反三: 学习完本题的思路你可以解决如下题目:…

牛客题解 | 括号生成

牛客输入输出题单题解题目 题目链接 题目主要信息:求n对括号的全部合法组合,左右括号之间任意组合,只要合法就行 需要输出所有的结果举一反三: 学习完本题的思路你可以解决如下题目: BM55. 没有重复项数字的全排列 BM56. 有重复项数字的全排列 BM58. 字符串的排列 方法:递…

牛客题解 | 按之字形顺序打印二叉树

牛客输入输出题单题解题目 题目链接 题目的主要信息:给定一个二叉树,返回该二叉树的之字形层序遍 第一层从左向右,下一层从右向左,一直这样交替举一反三: 学习完本题的思路你可以解决如下题目: JZ32. 从上往下打印二叉树 JZ78. 把二叉树打印成多行 方法一:非递归层次遍历…

牛客题解 | 接雨水问题

牛客输入输出题单题解题目 题目链接 题目主要信息:给定一个整型数组,数组每个元素表示下图所示的每列灰色柱子高度,数值都是非负数 在雨水(图中蓝色部分)不超过边界的情况下,问最多能有多少蓝色的格子 数组以外的区域高度视为0举一反三: BM93. 盛水最多的容器 方法:双指…

牛客题解 | 合并两个有序的数组

牛客输入输出题单题解题目 题目链接 题目主要信息:A与B是两个升序的整型数组,长度分别为\(n\)和\(m\) 需要将数组B的元素合并到数组A中,保证依旧是升序 数组A已经开辟了\(m+n\)的空间,只是前半部分存储的数组A的内容举一反三: 学习完本题的思路你可以解决如下题目: BM4. 合…

牛客题解 | 合并二叉树

牛客输入输出题单题解题目 题目链接 题目的主要信息:合并(相加)二叉树位置相同的节点 缺少的节点用另一棵树来补,若都缺则返回NULL举一反三: 学习完本题的思路你可以解决如下题目: BM28. 二叉树的最大深度 BM29. 二叉树中和为某一值的路径(一) BM31. 对称的二叉树 BM33…

牛客题解 | 反转字符串

牛客输入输出题单题解题目 题目链接 题目的主要信息:输入一个只包含小写字母的字符串 输出该字符串反转后的字符串举一反三: 学习完本题的思路你可以解决如下题目: BM87. 合并两个有序数组 BM88. 判断是否为回文字符串 方法一:双指针交换(推荐使用) 知识点:双指针 双指针…

DeepSeek+AnythingLLM,搭建本地AI知识库,真的太香了!三分钟搞定智能助手,小白也能轻松上手!

1、🌟 痛点暴击:你的知识管理还在原始时代吗? 你是否每次查找文档翻遍文件夹,会议纪要总在关键时刻“失踪”? 别慌!今天揭秘一个“真香”组合——DeepSeek+AnythingLLM,轻松搭建本地知识库,AI秒变你的“第二大脑”! 2、🚀 为什么选DeepSeek+AnythingLLM?三大优势碾…

H3C-msr-36-10引导损坏重装引导升级

1、去官网下载准备升级用的软件ipe 2、在用户 PC(假设 IP 地址为 192.168.0.23)上运行 TFTP Server 程序(3CDaemon软件),以 及正确的文件保存目录,并把待升级文件保存在 TFTP Server 的工作目录下。3、在用户 PC 上运行终端仿真程序,启动路由器,键入<Ctrl+B>,进…

专业文件摆渡系统vs传统文件传输,谁才是数据交换的王者?

一、传统文件传输方式的优缺点 在内外网隔离的环境下,文件摆渡是不可避免的需求,如何安全高效地进行文件传输成为了企业和组织面临的重要挑战。传统的文件传输方式,如U盘拷贝、FTP、邮件、网盘、网闸等,虽然简单易用,但在安全性、效率、管理等方面存在诸多不足。而专业的文…