面试算法-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;
    }
}
相关推荐
香芋Yu3 小时前
【大模型面试突击】10_推理部署与优化
面试·职场和发展
蚊子码农3 小时前
算法题解记录--239滑动窗口最大值
数据结构·算法
liliangcsdn3 小时前
A3C算法从目标函数到梯度策略的探索
算法
八月的冰可乐3 小时前
【无标题】
ai·面试
陈天伟教授4 小时前
人工智能应用- 材料微观:06.GAN 三维重构
人工智能·神经网络·算法·机器学习·重构·推荐算法
liliangcsdn4 小时前
A3C强化学习算法的探索和学习
算法
Figo_Cheung4 小时前
Figo《量子几何学:从希尔伯特空间到全息时空的统一理论体系》(二)
算法·机器学习·几何学·量子计算
额,不知道写啥。5 小时前
HAO的线段树(中(上))
数据结构·c++·算法
LYS_06185 小时前
C++学习(5)(函数 指针 引用)
java·c++·算法
紫陌涵光5 小时前
669. 修剪二叉搜索树
算法·leetcode