给定一个字符串,请你找出其中不含有重复字符的最长子串的长度。时间复杂度O(n)

利用滑动窗口方法解决给定字符串中不含有重复字符的最长子串长度问题,时间复杂度为O(n)。通过创建容器存储无重复字符子串,判断新增字符是否重复,重复则删除容器内重复元素并更新最长子串长度。详细步骤包括创建容器、检查重复字符、更新最长子串长度等。附带完整代码实现和运行结果。
摘要由CSDN通过智能技术生成

题目:给定一个字符串,请你找出其中不含有重复字符的最长子串 的长度。时间复杂度O(n)

示例一

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

示例二:

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

示例三:

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

思路:

  • 本题用“滑动窗口”方法解答。

  • 第一步:创建一个容器(注意:创建容器要调用头文件<vector>)存储无重复字符的长子串,并创建一个临时变量n储存容器的长度,创建一个变量MaxSize储存无重复字符的最长子串的长度。

	#include<vector>
	vector<char> test;	//创建一个容器
	int MaxSize(0), n(1);
  • 第二步:容器每新增加一个字符,建立一个for循环,判断该字符在容器中是否重复,若不重复,临时变量n++,若重复,则用容器删除方法erase()删除从容器的第一个元素到该重复元素。并且n的值要减去删除子串的长度,被删除字串的长度刚好该重复元素的下标值。
  • 例如:容器中若储存的元素为"abcdefg",此时n的值为7,新增元素为c,则将容器中的"abc"删除,剩下"defgc";因为原容器中c的下标为2,此时n
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

L丶丨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值