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

题目

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

子串

的长度。

示例 1:

输入: s = "abcabcbb"

输出: 3

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

java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        int n = s.length();
        Map<Character, Integer> map = new HashMap<>();
        int j = 0;
        int max = 0;
        for (int i = 0; i < n; i++) {
            if (map.get(s.charAt(i)) == null) {
                map.put(s.charAt(i), 1);
                max = Math.max(max, i - j + 1);
            } else {
                map.remove(s.charAt(j++));
                i--;
            }
        }
        return max;
    }
}
相关推荐
wostcdk15 分钟前
数论学习1
数据结构·学习·算法
我是中国人哦(⊙o⊙)38 分钟前
我的寒假作业
人工智能·算法·机器学习
.格子衫.1 小时前
030动态规划之树形DP——算法备赛
算法·动态规划
胡萝卜不甜1 小时前
算法宗门--冒泡排序(“懒”到极致的算法)
算法
charliejohn1 小时前
计算机考研 408 数据结构 中缀转后缀
数据结构·考研·算法
lifallen1 小时前
后缀数组 (Suffix Array)
java·数据结构·算法
仰泳的熊猫2 小时前
题目1523:蓝桥杯算法提高VIP-打水问题
数据结构·c++·算法·蓝桥杯
汉克老师2 小时前
GESP2024年3月认证C++二级( 第三部分编程题(1) 乘法问题)
c++·算法·循环结构·gesp二级·gesp2级
juleskk2 小时前
2.18复试训练
算法
tankeven2 小时前
HJ94 记票统计
c++·算法