当前位置: 首页 > article >正文

【LeetCode】【算法】3. 无重复字符的最长子串

LeetCode 3. 无重复字符的最长子串

题目描述

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

思路

思路:滑动窗口+哈希表

  1. 定义两个指针i,j,快指针j先走,将遍历到的字符都加入到哈希表map中,并通过Math.max()来找到res, j-i中的最大值(最长重复子串)
  2. 若遇到某个字符,在map中已经出现过(重复了),则慢指针i直接走到j的位置

代码

class Solution {
    public int lengthOfLongestSubstring(String s) {
        // 滑动窗口加哈希表
        Map<Character, Integer> map = new HashMap<>();
        int i = -1, res = 0, len = s.length();
        for (int j = 0; j < len; j++) {
            if (map.containsKey(s.charAt(j))) i = Math.max(i, map.get(s.charAt(j))); // 更新左指针
            map.put(s.charAt(j), j); // 哈希表记录
            res = Math.max(res, j - i); // 在遍历的过程中不断更新字符串长度
        }
        return res;
    }
}

http://www.kler.cn/a/390154.html

相关文章:

  • DAMA CDGA 备考笔记(二)
  • 【Linux】--- 进程的等待与替换
  • RabbitMQ的工作模式
  • ubuntu支持中文的字体
  • 迅翼SwiftWing | ROS 固定翼开源仿真平台正式发布!
  • 总结SpringBoot项目中读取resource目录下的文件多种方法
  • 单目视觉测量及双目视觉测量
  • AndroidStudio 加载grade失败问题解决
  • 企业级大数据安全架构
  • 二叉树搜索树(上)
  • 【lambda表达式】【DP】个人练习-Leetcode-1039. Minimum Score Triangulation of Polygon
  • QML —— 遮罩功能,模拟软件头像功能(附源码)
  • python printf中文乱码
  • JedisException:Could not get a resource from the pool
  • SpringCloud 微服务消息队列灰度方案 (RocketMQ 4.x)
  • SQL 窗口函数
  • 什么是C/C++,有什么特点
  • 物联网学习路线来啦!
  • 道可云人工智能元宇宙每日资讯|2024国际虚拟现实创新大会将在青岛举办
  • cache写策略 操作系统
  • nginx 部署2个相同的vue
  • 241111.学习日志——【CSDIY】Cpp零基础速成
  • 2024年11月10日系统架构设计师考试题目回顾
  • 【算法速刷(9/100)】LeetCode —— 42.接雨水
  • 2024年9月青少年软件编程(C语言/C++)等级考试试卷(四级)
  • flask logger 使用 TimedRotatingFileHandler 报错 PermissionError 另一个程序正在使用此文件