【Python 千题 —— 算法篇】无重复字符最长子段

news2025/1/23 4:08:53

请添加图片描述

Python 千题持续更新中 ……
脑图地址 👉:⭐https://twilight-fanyi.gitee.io/mind-map/Python千题.html⭐

字符串处理

题目背景

在编程过程中,处理字符串的任务时常遇到,其中一个经典问题是查找无重复字符的最长子串。这在很多应用场景中有实际价值,例如在文本处理、数据分析、加密技术等领域中,确保字符串的唯一性和最长性是至关重要的。本题目要求我们不仅要找出最长的无重复字符的子串,还要优化算法,以应对大量输入的需求。

通过本题的学习,我们可以进一步提升对字符串的理解和操作,掌握滑动窗口、哈希表等高效的算法技巧。

题目描述

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

你需要实现一个函数 lengthOfLongestSubstring(),该函数接收一个字符串 s 作为输入,并返回无重复字符的最长子串的长度。

输入描述

  • 一个字符串 s,长度不超过 10^5,只包含 ASCII 字符。

输出描述

  • 一个整数,表示无重复字符的最长子串的长度。

示例

示例 ①

输入:

# 调用 lengthOfLongestSubstring() 函数
print(lengthOfLongestSubstring("abcabcbb"))

输出:

3

解释:无重复字符的最长子串是 “abc”,其长度为 3。

示例 ②

输入:

print(lengthOfLongestSubstring("bbbbb"))

输出:

1

解释:最长子串是 “b”,其长度为 1。


代码讲解与多种解法

解法一:暴力破解法

最简单的解法是尝试枚举字符串中每一个子串,并判断这个子串中是否包含重复字符。这种方法需要嵌套循环遍历每个子串,并检查是否有重复字符。

def lengthOfLongestSubstring(s):
    def is_unique(substring):
        return len(substring) == len(set(substring))
    
    n = len(s)
    max_len = 0
    for i in range(n):
        for j in range(i + 1, n + 1):
            if is_unique(s[i:j]):
                max_len = max(max_len, j - i)
    
    return max_len

优点:

  • 思路清晰,容易理解和实现。

缺点:

  • 时间复杂度为 O(n^3),对于较大的字符串,效率较低。

解法二:滑动窗口

暴力破解法的最大问题是效率低下,因为每次需要重新检查整个子串。通过滑动窗口的思想,我们可以有效地减少重复计算。滑动窗口法通过使用两个指针(startend)来维护一个窗口,并通过移动指针来寻找符合条件的最长子串。

def lengthOfLongestSubstring(s):
    n = len(s)
    if n == 0:
        return 0
    
    char_set = set()
    max_len = 0
    left = 0
    
    for right in range(n):
        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

优点:

  • 时间复杂度降为 O(n),大大提高了性能。
  • 使用滑动窗口动态调整子串的范围,不需要重新计算每一个子串。

缺点:

  • 虽然时间复杂度较低,但内存占用可能稍大。

解法三:滑动窗口 + 哈希表

滑动窗口的效率已经不错,但我们还可以优化移除字符的操作。如果使用哈希表(即字典)来记录每个字符最后一次出现的位置,我们可以更加精确地调整窗口的左端,而不需要逐个移除字符。

def lengthOfLongestSubstring(s):
    n = len(s)
    if n == 0:
        return 0
    
    char_index = {}
    max_len = 0
    left = 0
    
    for right in range(n):
        if s[right] in char_index:
            left = max(char_index[s[right]] + 1, left)
        char_index[s[right]] = right
        max_len = max(max_len, right - left + 1)
    
    return max_len

优点:

  • 更加高效,进一步减少不必要的操作。
  • 保持 O(n) 的时间复杂度,并优化了滑动窗口的移动。

缺点:

  • 相较于滑动窗口,增加了一些额外的空间复杂度,用于存储哈希表。

总结与思考

在解决无重复字符最长子串问题时,我们可以通过多种方法进行尝试:

  1. 暴力破解法:适合初学者学习和理解,但实际应用中性能较差。
  2. 滑动窗口:通过维护一个窗口的字符集,减少了重复检查,提高了效率。
  3. 滑动窗口 + 哈希表:在滑动窗口的基础上进一步优化,通过哈希表来快速调整窗口,提升了效率。

在处理大型字符串数据时,选择合适的算法是至关重要的。滑动窗口和哈希表结合的算法是目前解决该类问题的最优选择,它在实际应用中的表现非常出色。

扩展思考

无重复字符的最长子串问题不仅仅是对字符的简单处理,它也能用于多个复杂场景,例如:

  • 在密码学中,寻找不重复的字符片段可以用于增强密码的安全性。
  • 在自然语言处理中,最长不重复子串可以帮助我们分析文本结构。
  • 在压缩算法中,可以利用不重复字符的子串来提升压缩效率。

通过本题的练习,不仅能够提升我们对字符串操作的理解,也能让我们在处理类似问题时有更好的应对方案。


希望通过本文的讲解,你能掌握无重复字符最长子串的几种常见算法,并学会如何在实际编程中高效地解决字符串问题!

持续关注博客,获取更多编程练习与技巧!
作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2114522.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux网络测试和故障排查命令

文章目录 ping 命令常用选项:使用示例:域名解析和 IP 地址响应数据停止 ping 命令统计数据延迟统计 traceroute 命令常用选项:使用示例:命令执行:路由节点详情: mtr 命令使用示例:使用结果详解输…

【持续更新】Adoobe Acroobat Pro DC 2024 (v24.3.20054)最新修改版

Adoobe Acroobat Pro DC 拥有智能工具,为您的沟通能力增添更多力量。使用包含丰富媒体元素的PDF文件进行创建与编辑,更加安全地分享信息,并且更高效地收集反馈意见。这款先进的软件程序是商务专业人士的理想选择,能够创建、合并、…

jmeter之ForEach控制器使用

ForEach控制器作用: 一般和用户自定义变量或者正则表达式提取器配合使用,读取返回结果中一系列相关的变量值,该控制器下的取样器都会被执行一次或多次,每次读取不同的变量值(类似python当中的for语句,用来遍历操作) 本节代码已上…

Spring6详细学习笔记(IOC+AOP)

一、Spring系统架构介绍 1.1、定义 Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器(框架)。Spring官网 Spring是一款主流的Java EE 轻量级开源框架,目的是用于简化Java企业级引用的开发难度和开发周期。从简单性、可测试性和松耦…

Qt-常用控件(3)-输入类

1. QLineEdit QLineEdit 用来表示单行输入框.可以输入一段文本,但是不能换行 核心属性 属性说明text输入框中的文本inputMask输入内容格式约束maxLength最大长度frame是否添加边框echoMode显示方式. QLineEdit::Normal :这是默认值,文本框会显示输入的文本。QLineE…

物联网之流水LED灯、正常流水灯、反复流水灯、移动流水灯

MENU 硬件电路设计软件程序设计正常流水LED灯反复流水LED灯移动流水LED灯 硬件电路设计 材料名称数量直插式LED1kΩ电阻杜邦线(跳线)若干面包板1 每一个LED的正极与开发板一个GPIO引脚相连,并串联一个电阻,负极接GND。 当然也可以选择只使用一个电阻。 软…

DELTA_IA-ASD_ASDA-A2简明教程

该文章仅供参考,编写人不对任何实验设备、人员及测量结果负责!!! 0 引言 文章主要介绍电机的硬件连接、软件配置、转动调试以及软件控制。文章中提到的内容在产品手册中都有说明,强烈建议在操作前通读产品手册&#…

1-17 平滑处理——中值滤波 opencv树莓派4B 入门系列笔记

目录 一、提前准备 二、代码详解 cv2.medianBlur函数用于对图像进行中值滤波。中值滤波是一种去噪声的技术,可以有效地去除图像中的盐和胡椒噪声。函数的两个参数如下: 三、运行现象 四、完整代码贴出 一、提前准备 1、树莓派4B 及 64位系统 2、提前…

【2024 版】最新 kali linux 入门及常用简单工具介绍(非常详细)

一、介绍 kali Linux Kali Linux 是一个基于 Debian 的 Linux 发行版,主要用于数字取证和渗透测试。它预装了大量的安全审计和渗透测试工具,被广泛应用于网络安全领域。 (一)特点 工具丰富:集成了数百种用于渗透测试…

华为eNSP:NAT Server(端口映射)

一、拓扑图 二、配置过程 此处省略设备地址以及路由配置过程 1、服务器开启ftp服务 2、路由器配置nat server [r4]int g0/0/2#进入流量出接口 [r4-GigabitEthernet0/0/2]nat server protocol tcp global 192.168.3.11 ftp inside 192.168.2.1 ftp# …

Java数组(详解版)

数组的定义: 什么是数组: 数组:可以看成是相同类型元素的一个集合。在内存中是一段连续的空间。 1. 数组中存放的元素其类型相同 2. 数组的空间是连在一起的 3. 每个空间有自己的编号,其实位置的编号为 0 ,即数组…

Nuxt3入门:过渡效果(第5节)

你好同学&#xff0c;我是沐爸&#xff0c;欢迎点赞、收藏、评论和关注。 Nuxt 利用 Vue 的 <Transition> 组件在页面和布局之间应用过渡效果。 一、页面过渡效果 你可以启用页面过渡效果&#xff0c;以便对所有页面应用自动过渡效果。 nuxt.config.js export defaul…

冒泡排序——基于Java的实现

简介 冒泡排序&#xff08;Bubble Sort&#xff09;是一种简单的排序算法&#xff0c;适用于小规模数据集。其基本思想是通过重复遍历待排序的数组&#xff0c;比较相邻的元素并交换它们的位置&#xff0c;以此将较大的元素逐步“冒泡”到数组的末尾。算法的名称源于其运行过程…

动手学习RAG: 向量模型

在世界百年未有之变局与个人自暴自弃的间隙中&#xff0c;我们学一点RAG。 RAG是一种独特的应用&#xff0c;“一周写demo&#xff0c;优化搞半年”&#xff0c;我甚至听说它能破解幻术。 为了理解其优化中的关键一环&#xff0c;我们先看下文本向量。文本向量除了是RAG检索的…

# 键盘字母上有下标数字,输入时怎么一键去掉,关闭键盘上的下标数字。‌

键盘字母上有下标数字&#xff0c;输入时怎么一键去掉&#xff0c;关闭键盘上的下标数字。‌ 一、问题描述&#xff1a; 如下图&#xff0c;有的笔记本电脑键盘上&#xff0c;没有数字小键盘&#xff0c;数字小键盘会和字母混和在一起&#xff0c;这样打字时&#xff0c;不容…

AI在医学领域:MASL多模态辅助诊断声带麻痹

声带麻痹&#xff08;Vocal Cord Paralysis, VP&#xff09;&#xff0c;也称为喉瘫痪&#xff0c;是指由于支配声带的神经受损导致声带运动障碍的疾病。这种状况可以是单侧或双侧的&#xff0c;通常由脑部、颈部、胸部的肿瘤、外伤、炎症&#xff0c;以及各种全身疾病引起。这…

复数随机变量(信号)的方差和协方差矩阵的计算

怎么计算复数随机变量的方差和协方差矩阵&#xff1f; 使得其与MATLAB中var函数和cov函数的结果一致。 前言 复信号在信号处理中随处可见&#xff0c;关于复信号&#xff08;复随机变量&#xff09;的方差和协方差矩阵该如何计算呢&#xff1f;本文给出了复信号的方差和协方差矩…

什么是大数据、有什么用以及学习内容

目录 1.什么是大数据&#xff1f; 2.大数据有什么用&#xff1f; 2.1商业与营销&#xff1a; 2.2医疗与健康&#xff1a; 2.3金融服务&#xff1a; 2.4政府与公共服务&#xff1a; 2.5交通与物流&#xff1a; 2.6教育与个性化学习&#xff1a; 3.学习大数据需要学习哪…

C++笔试强训12、13、14

文章目录 笔试强训12一、选择题1-5题6-10题 二、编程题题目一题目二 笔试强训13一、选择题1-5题6-10题 二、编程题题目一题目二 笔试强训14一、选择题1-5题6-10题 二、编程题题目一题目二 笔试强训12 一、选择题 1-5题 引用&#xff1a;是一个别名&#xff0c;与其被引用的实…

认知杂谈54

I I 内容摘要&#xff1a; 这篇内容主要有以下几个要点&#xff1a;首先&#xff0c;沟通不在一个调时可学习人际交往心理学知识、线上课程及关注名师来改善。其次&#xff0c;挑房子、工作、搭档和人生伴侣要谨慎&#xff0c;找心灵相通能共同进步的人。再者&#xff0c;远离…