leetcode3. 无重复字符的最长子串 [滑动窗口]

news2025/7/21 2:01:38

题目

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

示例 1:

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

示例 2:

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

示例 3:

输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
     请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

思路

设置两个指针left、right。固定left,向右移动right。设置set集合存储滑动窗口中的字符元素。

情况①,当s[right] 没有在set集合中找到时,就将它插入到set集合;

情况②,若在set集合中找到,则删除left指针指向的元素,直到set中没有与 s[right]相同的元素。

代码

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        // 10.17 19:00
        set<char> st;
        int len = s.size();
        int left = 0, right = 0;
        int res = 0;	// 最长子串长度
        while (left < len) {
            if (st.find(s[right]) == st.end()) {
                st.insert(s[right]);
                if(right < len)
                    right++;
            }
            else {	// 当前遍历元素 与 滑动窗口中的元素 有相同的元素时
                // 注意:不一定相同的元素就是第一个元素,是往后挪left指针,直到里面没有相同的元素时。
                char c = s[right];
                int length = right - left;
                if (length > res)	res = length;
                while (st.find(s[right]) != st.end()) {
                    st.erase(s[left++]);
                }
                // left++;
            }
        }
        return res;

    }
};

运行结果

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

蓝桥杯每日一题2023.10.17

迷宫 - 蓝桥云课 (lanqiao.cn) 题目描述 样例&#xff1a; 01010101001011001001010110010110100100001000101010 00001000100000101010010000100000001001100110100101 01111011010010001000001101001011100011000000010000 0100000000101010001101000010100000101010101100…

视频批量添加背景图片教程,详细步骤一看就会

你是否曾经需要为多个视频添加相同的背景图片&#xff1f;或者你需要为一些视频添加自定义的背景来增强视觉效果&#xff1f;如果你遇到了这样的问题&#xff0c;那么有一个软件可以帮助你解决&#xff0c;那就是固乔剪辑助手。下面是一个简单的步骤指南&#xff0c;教你如何使…

如何快速定位BUG?BUG定位技巧及测试人员定位的N板斧

很多测试人员可能会说&#xff0c;我的职责就是找到bug&#xff0c;至于找原因并修复&#xff0c;那是开发的事情&#xff0c;关我什么事&#xff1f; 好&#xff0c;我的回答是&#xff0c;如果您只想做一个测试人员最基本最本分的事情&#xff0c;那么可以这么想。但是&#…

基于边缘网关构建水污染监测治理方案

绿水青山就是金山银山&#xff0c;生态环境才是人类最宝贵的财富。但是在日常生活生产中&#xff0c;总是免不了各种污水的生产、排放。针对生产生活与环境保护的均衡&#xff0c;可以借助边缘网关打造环境污水监测治理体系&#xff0c;保障生活与环境的可持续性均衡发展。 水污…

数据结构-----红黑树(全)

目录 前言 一、什么是红黑树&#xff1f; 二、为什么需要红黑树&#xff1f;&#xff08;与AVL树对比&#xff09; 三、红黑树的特性 四、红黑树的储存结构 五、节点旋转操作 左旋&#xff08;Left Rotation&#xff09; 右旋&#xff08;Right Rotation&#xff09; 六、…

警惕!又2本Hindawi期刊被剔除,Scopus期刊目录更新!(附下载)

【SciencePub学术】 01Scopus目录更新概况 此次Scopus期刊目录更新后&#xff0c;有5本期刊不再被收录&#xff08;Discontinued titles September 2023&#xff09;&#xff0c;同上次更新时相比&#xff0c;此次又新增93本期刊(Accepted titles)进入Scopus数据库。目前Scop…

Intelijj中报java版本错误

这次编译一个半年没动过的老项目&#xff0c;报了几次版本错误&#xff0c;通过多次尝试最终解决掉了该问题 错误一&#xff1a;Diamond types are not supported at language level 6 错误背景 该错误出现在intelijj中&#xff0c;打开项目后&#xff0c;下面的代码的后一个…

红海云签约COMMUNE,新兴餐饮行业加速人力资源数字化转型

COMMUNE是一家连锁餐酒吧品牌&#xff0c;将酒水自选区、超级吧台与经典就餐区三大功能板块有机融合&#xff0c;创建“复合商超零售经典西式餐饮”模式&#xff0c;是面向新中产阶层消费客群的全时段餐酒吧。 近日&#xff0c;连锁餐酒吧品牌COMMUNE母公司极物思维集团与红海…

C++ Builder 将运行时需要的库打进运行的程序包

一、打开【工程】–【选项】–【Linker】-- 设置【Use dynamic RTL】为 False 二、打开【工程】–【选项】–【组件包】-- 设置【和运行时组件包一起编译】为 False

Apipost使用介绍

相信无论是前端&#xff0c;还是后端的测试和开发人员&#xff0c;都遇到过这样的困难。不同工具之间数据一致性非常困难、低效。多个系统之间数据不一致&#xff0c;导致协作低效、频繁出问题&#xff0c;开发测试人员痛苦不堪。 API管理的难点在哪&#xff1f; 开发人员在 …

Qt Creator编译含opencv的程序时报错libopencv_calib3d.so:-1: error: error adding symbols

错误信息&#xff1a; /home/lyc/Exe/opencv-3.4.16/opencv_install/lib/libopencv_calib3d.so&#x1f44e; error: error adding symbols: File in wrong format 进入libopencv_calib3d.so所在的目录&#xff0c;利用file查看文件格式。 由于libopencv_calib3d.so最终软链接…

Nginx的代理和负载均衡

一、nginx的代理方式 1.1 七层代理 七层代理&#xff1a;基于http协议&#xff0c;对请求的内容进行处理&#xff0c;然后转发到后端服务器 七层代理是客户端请求代理服务器&#xff0c;由代理服务器转发客户端的http请求&#xff0c;转发到内部的服务器进行处理(服务器可以是…

搭建NGINX服务 如何统计网页访问量

一、搭建Nginx服务 搭建之前需要查看一下我们的内核数制 我们进行简单的内核优化 命令&#xff1a;ulimit -n 65535 安装Nginx服务 第一步 关闭防火墙和安全机制 systemctl stop firewalld #关闭防火墙 systemct disable firewalld #开机自动关闭防火墙 setenfor…

Netty-SocketIo 完美替换 nodejs 的 socketio

背景 前段时间接到一个任务&#xff0c;用Java重构一个nodejs项目&#xff0c;其中用到了websocket的功能了&#xff0c;在nodejs项目中用的是socketio框架来实现websocket的功能&#xff0c;前端对应的也使用了socketio jar包。 一开始对socketio的用法并不是很清楚&#xff…

Unity Ugui 顶点颜色赋值

一、效果图 如下图&#xff1a;图片和文字的颜色都可以渐变&#xff0c;透明度也可以渐变。 原理分析&#xff1a; 不管是图片Image或是文本Text&#xff0c;它们都是网络Mesh来渲染网格是由很多三角形组成&#xff0c;那么我们根据坐标修改三角形的颜色即可实现。 工程源码…

进阶JAVA篇-如何理解作为参数使用的匿名内部类与 Arrays 类的常用API(九)

目录 目录 API 1.0 Arrays 类的说明 1.1 Arrays 类中的 toString() 静态方法 1.2 Arrays 类中的 copyOfRange(int[] original, int from, int to) 静态方法 1.3 Arrays 类中的 copyOf(int[] original, int newLength) 静态方法 1.4 Arrays 类中的 setAll(do…

论文研读|TextBack: Watermarking Text Classifiers using Backdooring

目录 论文信息文章简介研究动机研究方法水印生成水印嵌入版权验证 实验结果保真度 & 有效性消融实验 方法评估相关文献 论文信息 论文名称&#xff1a;TextBack: Watermarking Text Classifiers using Backdooring 作者&#xff1a;Nandish Chattopadhyay, et al. Nanyang…

如何选择靠谱且适合自己的IC公司?(内附各大厂薪资加班情况分析)

近期&#xff0c;有不少同学私信手里有几个offer&#xff0c;却不知道该怎么选择 &#xff1f;这着实令找不到工作的小伙伴们羡慕啊&#xff0c;今天IC修真院就来给大家分析一下如何选择靠谱且适合自己的IC公司 &#xff1f; 目前市面上可选择的芯片公司有哪些&#xff1f; 关…

SLM6500 适用于单节锂电池充电芯片 2A同步降压型鲤电池充电电路

SLM6500 是一款面向5V交流适配器的2A离子电池充电器。它是采用1.5MH2固定频率的同步降压型转换器&#xff0c;因此具有高达90%以上的充电效率&#xff0c;自身发热量极小。 SLM6500包括完整的充电终止电路、自动再充电和一个精确度达土1%的4.2V预设充电电压&#xff0c…

Linux | vim的入门手册

目录 前言 一、什么是vim 二、vim编辑器的模式 1、插入模式 &#xff08;1&#xff09;用vim打开文件 &#xff08;2&#xff09;进入插入模式 2、默认模式 &#xff08;1&#xff09;光标移动 &#xff08;2&#xff09;复制、粘贴与剪切操作 &#xff08;3&#x…