算法---滑动窗口练习-4(无重复字符的最长子串)

无重复字符的最长子串

  • 1. 题目解析
  • 2. 讲解算法原理
  • 3. 编写代码

1. 题目解析

题目地址:点这里

在这里插入图片描述

2. 讲解算法原理

在这里插入图片描述

在这里插入图片描述

算法的主要思想是使用滑动窗口来维护一个不含重复字符的子串。定义两个指针 left 和 right 分别表示窗口的左边界和右边界。还定义了一个数组 hash 来记录字符的出现次数。

算法的流程如下:

  1. 初始化 left、right、len 为0,字符串 s 的长度为 n。同时初始化一个大小为128的数组 hash,用于记录字符的出现次数,初始值都为0。
  2. 当 right 小于 n 时,执行以下步骤:
  • 将 hash[s[right]] 的值加1,表示当前字符进入窗口。
  • 当 hash[s[right]] 的值大于1时,表示当前字符在窗口内已经出现过,需要调整窗口的左边界。
    • 将 hash[s[left]] 的值减1,表示左边界字符移出窗口。
    • 将 left 右移一位。
  • 计算当前窗口的长度 right - left + 1,并将其与 len 中的最大值进行比较,更新 len。
  • 将 right 右移一位。
  1. 如果字符串 s 的长度为1,直接返回1,因为只有一个字符。
  2. 返回 len,即为最长的无重复字符子串的长度。

总体来说,这个算法利用滑动窗口的思想,在遍历字符串的过程中不断调整窗口的大小,以求得最长的无重复字符子串的长度。


3. 编写代码

class Solution {
public:int lengthOfLongestSubstring(string s) {int left=0,right=0,len=0;int n=s.size();int hash[128]={0};while(right<n){hash[s[right]]++;while(hash[s[right]]>1){hash[s[left]]--;//出窗口left++;}len=max(len,right-left+1);//更新结果right++;}if(n==1)return 1;return len;}
};

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

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

相关文章

#QT(一种朴素的计算器实现方法)

1.IDE&#xff1a;QTCreator 2.实验&#xff1a;这是全靠自己想法写的计算器&#xff0c;没有参考任何教程。 &#xff08;1&#xff09;这个计算器只要有运算符敲入就会进行一次运算&#xff0c;所以他没有先后之后&#xff0c;无法满足运算优先级。 &#xff08;2&#xff…

code摘录日记[矩阵变元素,变列向量,3D表面图,table行列设置] Matlab

矩阵变元素&#xff0c;变列向量 W1(Z1 < Z2) nan; % Z1,Z2 all matrix,Only plot points where Z1 > Z2;Z1 < Z2位置值填为NaNx x(:); % Now x is a 30-by-1 vector; matrix变列vector技巧3D表面图 hand figure; % Handle to the figure, for more plotting later…

XUbuntu22.04之关闭todesk开机自启动(二百二十一)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

C语言-strcmp(对比函数模拟和使用)

strcmp&#xff08;对比函数模拟和使用&#xff09; strcmp的语法 字符串的比较目的 这里比如你写一个网站&#xff0c;对照自己的用户和密码进行对比 使用(对比)方式 strcmp&#xff08;arr1&#xff0c;arr2&#xff09; 常量 arr1这里是常量 数组名是个地址所以是拷贝 …

QT网络编程之实现UDP广播发送和接收

推荐一个不错的人工智能学习网站&#xff0c;通俗易懂&#xff0c;内容全面&#xff0c;作为入门科普和学习提升都不错&#xff0c;分享一下给大家&#xff1a;前言https://www.captainbed.cn/ai 一.UDP通信 1.QT中实现UDP通信主要用到了以下类&#xff1a;QUdpSocket、QHost…

Spring Boot 集成 WebSocket 实例 | 前端持续打印远程日志文件更新内容(模拟 tail 命令)

这个是我在 CSDN 的第一百篇原则博文&#xff0c;留念&#x1f60e; #1 需求说明 先说下项目结构&#xff0c;后端基于 Spring Boot 3&#xff0c;前端为 node.js 开发的控制台程序。现在希望能够在前端模拟 tail 命令&#xff0c;持续输出后端的日志文件。 #2 技术方案 #2.…

Ansible自动化运维Inventory与Ad-Hoc

前言 自动化运维是指利用自动化工具和技术来简化、自动化和优化IT基础设施的管理和运维过程&#xff0c;从而提高效率、降低成本&#xff0c;并减少人为错误。在当今复杂的IT环境中&#xff0c;自动化运维已经成为许多组织和企业提高生产力和保证系统稳定性的重要手段。Ansibl…

react native常用插件

react-native-async-storage/async-storage 说明&#xff1a;AsyncStorage 是一个在 react-native 中轻量存储的库&#xff1b;跟 localStorage 类似&#xff0c;API 也几乎一样&#xff1b;存储的时候需要将存储内容转成字符串存储。 react-navigation/material-bottom-tabs …

SwiftUI的textfile

SwiftUI的textfile 记录一下SwiftUI的textfile的基本使用方法 import SwiftUIstruct TextfileBootCamp: View {State var enterString ""State var enterList [String]()var body: some View {NavigationView(content: {VStack {/// 双向绑定输入的字符TextField(…

泽众云真机-机型支持ADB调试功能即将上线

最近云真机平台在线客服&#xff0c;收到很多咨询关于ADB调试功能&#xff0c;什么时候能更新&#xff1f;据小编所知&#xff0c;正在升级之中&#xff0c;有一块专门为了解决ADB调试功能提前准备&#xff0c;升级网络硬件设备&#xff0c;目前平台的功能已开发完成&#xff0…

使用docker-compose部署MySQL三主六从半同步集群(MMM架构)

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容部署MySQL三主六从半同步集群一主二从同步集群规划需要安装docker和docker-compose命令形式安装安装docker安装docker-compose 宝塔面板形式安装 部署node1节点的master1docker-compose.yaml文件my.cnf文件授权启动 部署no…

C# danbooru Stable Diffusion 提示词反推 Onnx Demo

目录 说明 效果 模型信息 项目 代码 下载 C# danbooru Stable Diffusion 提示词反推 Onnx Demo 说明 模型下载地址&#xff1a;https://huggingface.co/deepghs/ml-danbooru-onnx 效果 模型信息 Model Properties ------------------------- ----------------------…