面试算法-141-无重复字符的最长子串

题目

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

子串

的长度。

示例 1:

输入: s = "abcabcbb"

输出: 3

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

java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        int n = s.length();
        int left = 0;
        int right = 0;
        int maxLen = 0;
        Map<Character, Integer> map = new HashMap<Character, Integer>();
        while (left <= right && right < n) {
            Character chRight = s.charAt(right);
            if (map.get(chRight) == null) {
                map.put(chRight, 1);
                right++;
            } else {
                Character chLeft = s.charAt(left++);
                map.remove(chLeft);
            }

            maxLen = Math.max(maxLen, right - left);
        }
        return maxLen;
    }
}
相关推荐
你撅嘴真丑12 分钟前
字符环 与 变换的矩阵
算法
早点睡觉好了29 分钟前
重排序 (Re-ranking) 算法详解
算法·ai·rag
gihigo199833 分钟前
基于全局自适应动态规划(GADP)的MATLAB实现方案
算法
ctyshr2 小时前
C++编译期数学计算
开发语言·c++·算法
zh_xuan2 小时前
最小跳跃次数
数据结构·算法
yumgpkpm2 小时前
2026软件:白嫖,开源,外包,招标,晚进场(2025年下半年),数科,AI...中国的企业软件产业出路
大数据·人工智能·hadoop·算法·kafka·开源·cloudera
孞㐑¥2 小时前
算法—队列+宽搜(bfs)+堆
开发语言·c++·经验分享·笔记·算法
yufuu982 小时前
并行算法在STL中的应用
开发语言·c++·算法
zh_xuan2 小时前
单青蛙跳台阶
数据结构·算法
Kx_Triumphs2 小时前
计算几何-旋转卡壳两种实现方案(兼P1452题解
算法·题解