[leetcode hot 150]第三题,无重复字符的最长子串

题目:

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

可以使用"滑动窗口"的方法来解决这个问题。基本思路如下:

  1. 使用两个指针(start和end)来定义一个窗口
  2. 移动end指针来扩大窗口,直到遇到重复字符
  3. 如果遇到重复字符,移动start指针来缩小窗口,直到删除重复字符
  4. 在这个过程中,持续更新最长子串的长度
java 复制代码
public class no_3 {
    public static void main(String[] args) {
        System.out.println(lengthOfLongestSubstring("abcabcbb"));
    }

    public static int lengthOfLongestSubstring(String s) {
        int n = s.length();
        int maxLength = 0;
        int[] charIndex = new int[128]; //  用于存储字符最后出现的位置

        int start = 0;

        for (int end = 0; end < n; end++) {
            char c = s.charAt(end);

            start = Math.max(charIndex[c], start);

            maxLength = Math.max(maxLength, end - start + 1);

            charIndex[c] = end + 1;
        }

        return maxLength;
    }
}
相关推荐
轮到我狗叫了5 分钟前
力扣热题100,力扣148.排序链表力扣.26找出字符串中第一个匹配项的下标力扣146.LRU缓存序列管理器
算法·leetcode·职场和发展
2301_794461571 小时前
力扣-三数之和
数据结构·算法·leetcode
徐行tag4 小时前
深度学习基础——神经网络优化算法
深度学习·神经网络·算法
liuzhangfeiabc6 小时前
[luogu12541] [APIO2025] Hack! - 交互 - 构造 - 数论 - BSGS
c++·算法·题解
平和男人杨争争8 小时前
山东大学计算机图形学期末复习15——CG15
人工智能·算法·计算机视觉·图形渲染
爱coding的橙子9 小时前
每日算法刷题Day11 5.20:leetcode不定长滑动窗口求最长/最大6道题,结束不定长滑动窗口求最长/最大,用时1h20min
算法·leetcode·职场和发展
WenGyyyL9 小时前
力扣热题——零数组变换 |
算法·leetcode·职场和发展·蓝桥杯
芯眼9 小时前
AMD Vivado™ 设计套件生成加密比特流和加密密钥
算法·fpga开发·集成测试·软件工程
咪嗷喵挖藕哇9 小时前
leetcode 合并区间 java
java·算法·leetcode
沐风ya9 小时前
leetcode每日一题 -- 3355. 零数组变换 I
算法·leetcode