【leetcode】3. 无重复字符的最长子串

文章目录

    • 题目
    • 题解
      • [1. 暴力求解+集合](#1. 暴力求解+集合)
      • [2. 滑动窗口](#2. 滑动窗口)

题目

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

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

示例 1:

输入: s = "abcabcbb"

输出: 3

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

示例 2:

输入: s = "bbbbb"

输出: 1

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

示例 3:

输入: s = "pwwkew"

输出: 3

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

请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

题解

1. 暴力求解+集合

python 复制代码
在这里插入代码片class Solution(object):
    def lengthOfLongestSubstring(self, s):
        """
        :type s: str
        :rtype: int
        """
        if len(s) == 0:
            return 0
        # 暴力求解
        result = 0
        n = len(s)

        for i in range(n):
            seen = set()
            lenth = 0 
            for j in range(i, n):
                if s[j] not in seen:
                    seen.add(s[j])
                    lenth += 1
                else:
                    break
            result = max(result, lenth)
        return result

        

2. 滑动窗口

python 复制代码
class Solution(object):
    def lengthOfLongestSubstring(self, s):
        """
        :type s: str
        :rtype: int
        """
        # 使用一个集合来记录当前窗口内的字符
        char_set = set()
        left = 0  # 窗口的左边界
        max_len = 0  # 记录最长子串的长度

        for right in range(len(s)):
            # 如果字符已经在集合中,移动左边界
            while s[right] in char_set:
                char_set.remove(s[left])  # 移除左边界的字符
                left += 1  # 将左边界向右移动
            
            # 将当前字符加入集合
            char_set.add(s[right])
            # 更新最长子串长度
            max_len = max(max_len, right - left + 1)

        return max_len


        
相关推荐
王哈哈^_^4 分钟前
【完整源码+数据集】蓝莓数据集,yolo11蓝莓成熟度检测数据集 3023 张,蓝莓成熟度数据集,目标检测蓝莓识别算法系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·ai·视觉检测
王哈哈^_^17 分钟前
【完整源码+数据集】高空作业数据集,yolo高空作业检测数据集 2076 张,人员高空作业数据集,目标检测高空作业识别系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·目标跟踪·视觉检测
一条数据库23 分钟前
猫狗识别数据集:34,441张高质量标注图像,深度学习二分类任务训练数据集,计算机视觉算法研发,CNN模型训练,图像识别分类,机器学习实践项目完整数据资
深度学习·算法·机器学习
bloxd yzh34 分钟前
图论基础概念
算法
小白程序员成长日记37 分钟前
2025.11.09 力扣每日一题
算法·leetcode·职场和发展
hansang_IR38 分钟前
【题解】洛谷 P1477 [NOI2008] 假面舞会 [思维 + 图论]
c++·算法·图论·思维
天选之女wow41 分钟前
【代码随想录算法训练营——Day59】图论——47.参加科学大会、94.城市间货物运输I
算法·图论
CoovallyAIHub1 小时前
1.2MB超轻量模型实现草莓苗精准分级检测与定位,准确率超96%
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
终结AI偏见!Sony AI发布Nature论文与FHIBE数据集,重塑公平性评估基准
深度学习·算法·计算机视觉
7澄11 小时前
深入解析 LeetCode 1572:矩阵对角线元素的和 —— 从问题本质到高效实现
java·算法·leetcode·矩阵·intellij-idea