LeetCode Hot100 3.无重复字符的最长子串

题目描述

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

3. 无重复字符的最长子串 - 力扣(LeetCode)

思路

维护一个滑动窗口,保证滑动窗口内的子串无重复字符。当一个新字符即将进入窗口时,需要判断该字符是否在窗口中出现过,这个时候就需要使用hashmap保存字符及字符最后出现的下标。

如果新字符在map里出现过,但不一定存在于窗口中,为了防止指针回退,写成

java 复制代码
l=Math.max(l,map.get(c)+1);

代码

java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        HashMap<Character,Integer> map = new HashMap<>();
        int l=0,maxLen=0;
        for(int r=0;r<s.length();r++){
            char c=s.charAt(r);
            if(map.containsKey(c)){
                l=Math.max(l,map.get(c)+1);
            }
            map.put(c,r);
            maxLen=Math.max(maxLen,r-l+1);
        }
        return maxLen;
    }
}
相关推荐
洛水水1 小时前
【力扣100题】18.随机链表的复制
算法·leetcode·链表
南宫萧幕2 小时前
规则基 EMS 仿真实战:SOC 区间划分与 Simulink 闭环建模全解
算法·matlab·控制
多加点辣也没关系2 小时前
数据结构与算法|第二十三章:高级数据结构
数据结构·算法
hoiii1874 小时前
孤立森林 (Isolation Forest) 快速异常检测系统
算法
c++之路5 小时前
适配器模式(Adapter Pattern)
java·算法·适配器模式
吴声子夜歌6 小时前
Java——接口的细节
java·开发语言·算法
myheartgo-on6 小时前
Java—方 法
java·开发语言·算法·青少年编程
宝贝儿好7 小时前
【LLM】第三章:项目实操案例:智能输入法项目
人工智能·python·深度学习·算法·机器人
雪碧聊技术8 小时前
上午题_算法
算法·软考·软件设计师