LeetCode Medium|【3. 无重复字符的最长子串】
创始人
2024-11-11 21:34:30
0

力扣题目链接
状态:在本题中,我们可以很明显得看出出现了关键字:子串、最长,所以我们肯定是选用滑动窗口来解决这个题目。
滑动窗口首先要解决的就是我们选择什么样的容器来存储数据呢?本体中是计算重复字符,我们可以使用 set、map、数组均可以解决,这里分别给出三种方法。

set

这个非常直观,和我们做的一些滑动窗口的基础题是一样的

class Solution { public:     int lengthOfLongestSubstring(string s) {         std::unordered_set set;         int left = 0, right = 0;         int ans = 0;          while (right < s.length()) {             char rChar = s[right];             while (set.find(rChar) != set.end()) {                 set.erase(s[left]);                 left++;             }             set.insert(rChar);             ans = max(ans, right - left + 1);             right++;         }          return ans;     } }; 

map

对于 map ,我们最需要搞清楚的就是 key 和 value ,这里我们的 key 肯定是字符,然后 value 肯定是对应的下标,因为我们的 map 只能去搜索 key。

这样的话我们就不需要内层循环了,可以直接更新 left 。如何更新呢?当然就是把重复字符排除在外,但是为了防止 left 的回退,所以我们有:

left = max(left, map[rChar] + 1); 

这样的代码。

class Solution { public:     int lengthOfLongestSubstring(string s) {         std::unordered_map map;         int left = 0, right = 0;         int ans = 0;          while (right < s.length()) {             char rChar = s[right];             if (map.find(rChar) != map.end()) {                 left = max(left, map[rChar] + 1);             }             map[rChar] = right;             ans = max(ans, right - left + 1);             right++;         }          return ans;     } }; 

数组

对于数组,解法和 map 其实非常类似。
我们第一反应肯定就是 26 个英文字母,但是由于我们题目中要求了 「s由英文、数字、符号和空格组成」,所以很自然的想法就是 255 来表示 ASCII 码。

同样的,我们在数组中存储的是对应的下标位置。

class Solution { public:     int lengthOfLongestSubstring(string s) {         vector index(256, -1);         int left = 0, right = 0;         int ans = 0;          while (right < s.length()) {             char rChar = s[right];             if (index[rChar] != -1 && index[rChar] >= left) {                 left = max(left, index[rChar] + 1);             }             index[rChar] = right; //还是隐式类型转换             ans = max(ans, right - left + 1);             right++;         }          return ans;     } }; 

相关内容

热门资讯

今天下午!海盗来了辅助器无限炮... 今天下午!海盗来了辅助器无限炮!真是真的是有辅助app(有挂神器)-哔哩哔哩1、很好的工具软件,可以...
据文件显示!汇友游戏辅助!确实... 据文件显示!汇友游戏辅助!确实真的是有辅助app(竟然有挂)-哔哩哔哩1、实时汇友游戏辅助透视辅助更...
现有关情况通报如下!大菠萝提高... 现有关情况通报如下!大菠萝提高好牌几率!好像存在有辅助插件(今日头条)-哔哩哔哩大菠萝提高好牌几率是...
据通报!情怀破解!真是真的是有... 据通报!情怀破解!真是真的是有辅助软件(有挂分享)-哔哩哔哩1、下载好情怀破解脚本下载之后点击打开,...
无独有偶!心悦海南苹果版辅助!... 无独有偶!心悦海南苹果版辅助!切实有挂辅助平台(确实有挂)-哔哩哔哩1、很好的工具软件,可以解锁游戏...
现有关情况通报如下!新财神正版... 现有关情况通报如下!新财神正版辅助挂!原来存在有辅助挂(证实有挂)-哔哩哔哩1、超多福利:超高返利,...
据报道!闲逸官方辅助软件叫什么... 据报道!闲逸官方辅助软件叫什么名字!本来真的是有辅助下载(存在有挂)-哔哩哔哩1、首先打开闲逸官方辅...
现有关情况通报如下!丽水欢乐堂... 现有关情况通报如下!丽水欢乐堂辅助插件!竟然是真的辅助下载(有挂分享)-哔哩哔哩1、许多玩家不知道丽...
随着!微信小程序家乡大二辅助工... 随着!微信小程序家乡大二辅助工具!竟然真的有辅助挂(有挂头条)-哔哩哔哩微信小程序家乡大二辅助工具能...
据监测!拱趴大菠萝的辅助器!一... 据监测!拱趴大菠萝的辅助器!一直是真的辅助下载(讲解有挂)-哔哩哔哩1、每一步都需要思考,不同水平的...