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;
    }
}
相关推荐
Justice Young7 小时前
算法分析与设计实验:贪心法求解0/1背包问题的局限性
算法
酉鬼女又兒7 小时前
零基础入门计算机网络:从基本概念到核心交换技术
开发语言·计算机网络·考研·职场和发展·php
黎阳之光7 小时前
无感定位·智管全域:黎阳之光人员无感定位管理系统,重新定义安全与效率
人工智能·物联网·算法·安全·数字孪生
小许同学记录成长7 小时前
网格简化算法 — Edge Collapse(边塌缩)
qt·算法
凯瑟琳.奥古斯特7 小时前
力扣1001网格照明解法
算法·leetcode·职场和发展
川石课堂软件测试7 小时前
作为一名测试工程师如何学习Kubernetes(k8s)技能
学习·测试工具·容器·职场和发展·kubernetes·测试用例·harmonyos
fengenrong7 小时前
20260601
算法·深度优先·图论
晚笙coding7 小时前
从“看起来像双指针”到真正的动态规划 —— 最长公共子序列
算法·动态规划
05候补工程师8 小时前
【考研高数核心突破】极限的本质、高频解题套路与海涅定理深度解析(附经典例题思维导图式拆解)
经验分享·笔记·考研·算法
智者知已应修善业8 小时前
【51单片机8个LED的花样12亮34熄56间隔78闪烁3秒3闪烁】2023-11-4
c++·经验分享·笔记·算法·51单片机