question:
my thinking:
首先明确最终要得到最长不重复字符串的长度,就要记录下最长不重复字符串的起始位置和结束位置(当然可能很多朋友有别的更好的做法,觉得不需要这些也可以,不过这样的一个好处是我们还可以知道是哪个字串是我们要求的最长字串,虽然题目没有要求,但是说不定面试的时候面试官就会加上这一问呢,这里也就相当于是给自己加点难度吧)
那么接下来的操作就是通过改变start和end的下标值来确定我们的答案了。
从头开始遍历string,如果发现此时的字母还没有在之前最长的字串里出现过,就增加end的值,当然如果此时已经到了string的末尾就直接计算max_len和此时字串的长度的max值返回就可以了;
如果此时的字幕已经在之前的字符串里出现过了,那么就更新一下max_len的值,并且改变之前最长字串的start后第一个非该字母的位置,改变end为当前的下标
my Answer:
还是那句话,个人拙见,还希望和各位朋友多多交流
leetcode-Longest Substring Without Repeating Characters
最新推荐文章于 2025-05-18 01:04:12 发布
本文介绍了一种寻找字符串中最长不重复子串的方法。通过调整起始和结束索引来跟踪最长不重复子串的变化,实现高效求解。不仅讨论了算法的基本思路,还涉及如何确定最长子串的具体内容。

350

被折叠的 条评论
为什么被折叠?



