3. 无重复字符的最长子串(哈希表 滑动窗口)(Leetcode刷题笔记)
https://lunan0320.cn
文章目录
题目
给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: s = “abcabcbb”
输出: 3
解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。
示例 2:
输入: s = “bbbbb”
输出: 1
解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。
示例 3:
输入: s = “pwwkew”
输出: 3
解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。
请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。
示例 4:
输入: s = “”
输出: 0
解题代码 C++(核心代码)
class Solution {
public:
int lengthOfLongestSubstring(string s) {
int maxLength = 0;
//创建哈希表
unordered_map<char, int> window;
int left = 0, right = 0;
//遍历一次
while (right < s.size()) {
char c = s[right];
right++;
//对遍历到的放入哈希表中
window[c]++;
//窗口收敛过程
while (window[c] > 1) {
char d = s[left];
window[d]--;
left++;
}
//判断最大长度是关键,此处right-left不需要+1,因为之前的right已经实现了++
maxLength = maxLength < right - left ? right - left : maxLength;
}
return maxLength;
}
};
解题代码 C++(本地编译运行)
//head.h
#include<iostream>
#include <string>
#include <unordered_map>
using namespace std;
//myWindow4.h
#include "head.h"
class myWindow4 {
public:
int lengthOfLongestSubstring(string s) {
int maxLength = 0;
//创建哈希表
unordered_map<char, int> window;
int left = 0, right = 0;
//遍历一次
while (right < s.size()) {
char c = s[right];
right++;
//对遍历到的放入哈希表中
window[c]++;
//窗口收敛过程
while (window[c] > 1) {
char d = s[left];
window[d]--;
left++;
}
//判断最大长度是关键,此处right-left不需要+1,因为之前的right已经实现了++
maxLength = maxLength < right - left ? right - left : maxLength;
}
return maxLength;
}
};
//myWindow.cpp
#include "myWindow4.h"
int main() {
myWindow4 solution;
string s = "abcabcbb";
cout << solution.lengthOfLongestSubstring(s) << endl;
return 0;
}