面试算法-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;
    }
}
相关推荐
jiayong236 分钟前
前端面试题库 - 浏览器与网络篇
前端·网络·面试
叶小鸡21 分钟前
小鸡玩算法-力扣HOT100-动态规划(上)
算法·leetcode·动态规划
LuminousCPP27 分钟前
数据结构 - 线性表第三篇:基于顺序表实现 C 语言通讯录(基础功能篇)
c语言·数据结构·经验分享·笔记·算法
一叶遮惊鸿31 分钟前
从零构建 AI 驱动的日志监控自愈系统
面试
_日拱一卒31 分钟前
LeetCode:114二叉树展开为链表
java·开发语言·算法
李小狼lee33 分钟前
《spring如此简单》第四节--IOC思想的实现,spring启动后发生了什么
后端·面试
2301_8008951035 分钟前
计算机网络保研面试(自用版h)
计算机网络·面试
SamDeepThinking37 分钟前
面试官问Bean线程安全,你该从架构角度回答
java·后端·面试
无小道41 分钟前
Redis——哈希类型相关指令
redis·算法·哈希算法
凌波粒43 分钟前
LeetCode--513.找树左下角的值(二叉树)
java·算法·leetcode