leecode题解Golang版本-3-无重复字符最长子串

题目

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

题解

func lengthOfLongestSubstring(s string) int {m := make(map[uint8]int)res := 0for l, r := 0, 0; r < len(s); r++ {m[s[r]]++if v, ok := m[s[r]]; !ok || v == 1 {length := r - l + 1if length > res {res = length}} else {for s[l] != s[r] {m[s[l]]--l++}m[s[l]]--l++}}return res}

核心细节一: 使用滑动窗口寻找合适子串

首先我们阐述一下,为什么使用滑动窗口可以去用来求解这类问题。对于这个题目,如果我们使用暴力破解的方式大概应该怎么做?
在这里插入图片描述

以上图为例,我们可以采取如下的解法:
以一号位A为子串的终点,向前探索一个最大不重复子串
以二号位D为子串的终点,向前探索一个最大不重复子串
以三号位O为子串的终点,向前探索一个最大不重复子串

我们可以借用map来统计字符字串是否有相同的元素,这样我们大概可以得出以下解法:

func search(s string, index int) int {m := make(map[uint8]int)res := 0for i := index; i >= 0; i-- {if _, ok := m[s[i]]; ok {break}m[s[i]] = 1res++}return res
}func lengthOfLongestSubstring(s string) int {res := 0for i := 0; i < len(s); i++ {res = max(res, search(s, i))}return res
}func max(a, b int) int {if a > b {return a} else {return b}
}

这种解法的算法复杂度是o(n2),读者可以注意到,其实这个解法中做了很多重复性质的工作。我们在每一次切换字符串终点的时候,都在重新往前推进,逐个统计当前字符子串中是否有相同元素。但其实历史元素中的最大不重复字符子串是已经统计过的。如下图所示,我们以A为字符串末尾时,前面一个元素作为字符串末尾的最长不重复字串我们时已经计算过的。

以B为末端最长子串:AODB
使用map统计的结是:
A:1
O:1
D:1
B:1

我们在右端新增一个元素A,会发现统计map变成了

以A为末端最长子串:AODBA
使用map统计的结是:
A:2
O:1
D:1
B:1

为了保证子字符串不含相同元素,我们要将左端收缩到删除重复元素A。
在这里插入图片描述
这么一同分析,题解就简化成了一个滑动窗口的解法。滑动窗口的右端不断增加元素,如果滑动窗口有相同元素,就收缩左端。这种解法的时间复杂度简化到了o(n)。

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

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

相关文章

速盾网络:业务卓越,数字安全的领先者

在数字时代的浪潮中&#xff0c;业务成功需要强大的数字基石。速盾网络以其出色的CDN加速、高防IP、SDK游戏盾和抗DDoS攻击等业务&#xff0c;成为业界领先的数字安全保障者&#xff0c;为您的业务提供全方位的支持与保护。 CDN加速&#xff1a;业务飞跃的翅膀 速盾网络以全球…

设计模式详解---模板方法模式

1. 模板方式概念 当需要定义一个算法的框架&#xff0c;但允许具体步骤在子类中灵活实现时&#xff0c;可以使用模板方法&#xff08;Template Method&#xff09;设计模式。该模式通过定义一个模板方法以及一组抽象方法&#xff0c;将算法的结构固定&#xff0c;但具体实现延…

算法基础课-基础算法-二分查找-数的范围

lmid 需要补上加一 rmid 不需要补上加一 789. 数的范围 题目 提交记录 讨论 题解 视频讲解 给定一个按照升序排列的长度为 n&#xfffd; 的整数数组&#xff0c;以及 q&#xfffd; 个查询。 对于每个查询&#xff0c;返回一个元素 k&#xfffd; 的起始位置和终止位…

智能优化算法应用:基于世界杯算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于世界杯算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于世界杯算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.世界杯算法4.实验参数设定5.算法结果6.参考文…

小程序自定义轮播图样式

小程序自定义轮播图样式以下是各案例&#xff0c;仅供大家参考。 效果展示&#xff1a; index.wxml代码&#xff1a; <view><!-- 轮播 --><view><swiper indicator-dots"{{indicatorDots}}"autoplay"{{autoplay}}" interval"{{…

数据可视化的魅力你了解吗?

你真的了解数据可视化吗&#xff1f;它所具备的真正魅力可能远远超出我们想象。数据可视化扩展了我们对数字和信息的简单理解&#xff0c;为我们揭示了一个无限可能的世界。今天我就以可视化行业的多年工作经验出发&#xff0c;和大家简单聊聊数据可视化的魅力。 数据的故事化…

SAP ABAP EXCEL 下载模板并导入

具体参考&#xff1a; ABAP EXCEL 下载摸板 获取数据模板文件路径 FORM fm_get_filepath .DATA: lv_filename TYPE string,lv_path TYPE string,lv_fullpath TYPE string,lv_title TYPE string.co_objid ZMMRP002.CONCATENATE co_objid - sy-datum sy-uzeit INTO l…

Flink系列之:Table API Connectors之Raw Format

Flink系列之&#xff1a;Table API Connectors之Raw Format 一、Raw Format二、示例三、Format 参数四、数据类型映射 一、Raw Format Raw format 允许读写原始&#xff08;基于字节&#xff09;值作为单个列。注意: 这种格式将 null 值编码成 byte[] 类型的 null。这样在 ups…

STM32——时钟树与滴答计时器

STM32——时钟树与滴答计时器 使用的开发板为stm32F407VET6的芯片,主要介绍stm32的时钟树与滴答计时器的一些理论和一个自己编写的delay函数。 时钟树的结构图可以在STM32F4xx中文参考手册.pdf中的时钟这块找到。而滴答计时器是内核资源&#xff0c;需要到Cortex M3与M4权威指南…

【VScode】设置语言为中文

1、下载安装好vscode 2、此时可看到页面为英文&#xff0c;为方便使用可切换为中文 3、键盘按下 ctrlshiftP 4、在输入框内输入configure display language 5、选择中文&#xff0c;restart即可&#xff08;首次会有install安装过程&#xff0c;等待安装成功后重启即可&am…

CMPXCHG和lwarx (LL)/stwcx (SC)

CMPXCHG 指令和 lwarx/stwcx&#xff08;LL/SC&#xff09;指令是在不同体系结构中常见的原子操作指令。 CMPXCHG: CMPXCHG 是 x86 架构中用于执行原子比较并交换操作的指令。这个指令会比较某个内存位置的值与累加器中的值&#xff0c;如果相等&#xff0c;则将累加器中的值赋…

算法设计与分析2023秋-头歌客观题-张超(云南农业大学)

文章目录 第一章客观题练习关于算法描述正确的是&#xff08; &#xff09;算法的要素包括&#xff08; &#xff09;分析算法&#xff0c;最重要的是衡量算法哪两个方面的效率&#xff08; &#xff09;算法的表示方法有&#xff08; &#xff09; 第二章客观题练习关于算法分…

nodejs+vue+微信小程序+python+PHP国漫推荐系统-计算机毕业设计推荐

使得本系统的设计实现具有可使用的价。做出一个实用性好的国漫推荐系统&#xff0c;使其能满足用户的需求&#xff0c;并可以让用户更方便快捷地国漫推荐。这个系统的设计主要包括系统页面的设计和方便用户互动的后端数据库&#xff0c;在开发后需要良好的数据处理能力、友好的…

git push提交出现Everything up-to-date提示问题

以前通过git提交代码到GitHub上的个人main分支时&#xff0c;曾出现过这样一个很低级的错误—— 出现这个错误原因&#xff0c;其实就是没有正确执行指令造成的&#xff0c;也就是没有正常提交数据。 一般按照以下命令提交&#xff0c;基本就没什么问题了—— git add . #添…

5路开关量转继电器 Modbus TCP远程I/O模块 YL95 RJ-45网络接口通信

特点&#xff1a; ● 五路开关量输入&#xff0c;五路继电器输出 ● 支持Modbus TCP 通讯协议 ● 内置网页功能&#xff0c;可以通过网页查询电平状态 ● 可以通过网页设定继电器输出状态 ● DI信号输入&#xff0c;DO输出及电源之间互相隔离 ● 宽电源供电范围&#x…

面试题,手写soft_nms

目录 有原理步骤&#xff1a; 加注释版&#xff1a; soft_nms的优点 有原理步骤&#xff1a; soft-nms详解_笔记大全_设计学院 Soft-nms的实现过程可以分为几个步骤&#xff1a; 1. 输入预测框 输入神经网络预测输出的所有框&#xff0c;每个框有四个坐标和一个类别得分…

选择排序、快速排序和插入排序

1. 选择排序 xuanze_sort.c #include<stdio.h> #include<stdlib.h>//选择排序void xuanze_sort(int arr[],int sz){//正着for(int i0;i<sz;i){//外层循环从第一个数据开始依次作为基准数据for(int j i1;j<sz;j){//int j i1 因为第一个数据作为了基准数据&…

本地缓存与多级缓存

一、前言 缓存对于一个高并发场景下的微服务应用来说具有重要的作用&#xff0c;不管是在架构选型还是设计阶段&#xff0c;缓存都是应用扛高并发提升吞吐量的有效手段。缓存对于大多数开发的同学来说并不陌生&#xff0c;一个基本的缓存使用流程如下&#xff1a; 简而言之&am…

Hugging Face实战-系列教程20:文本摘要建模实战2 之 Tokenizer处理

&#x1f6a9;&#x1f6a9;&#x1f6a9;Hugging Face 实战系列 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Jupyter Notebook中进行 本篇文章配套的代码资源已经上传 文本摘要建模实战1 之 数据清洗 文本摘要建模实战2 之 Tokenizer处理 3 Tokenizer处理 …

ArcGIS Pro SDK导出的几何XML和Json

本博主会持续更新关于ArcGIS Pro SDK的相关内容&#xff0c;请读者关注一下 圆 XML <PolygonN xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xmlns:xs"http://www.w3.org/2001/XMLSchema" xmlns:typens"http://www.esri.com/schemas/…