leetcode 3. 无重复字符的最长子串
一、题目描述
给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: s = “abcabcbb”
输出: 3
解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。
示例 2:
输入: s = “bbbbb”
输出: 1
解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。
示例 3:
输入: s = “pwwkew”
输出: 3
解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。
请注意,你的答案必须是 子串 的长度,”pwke” 是一个子序列,不是子串。
示例 4:
输入: s = “”
输出: 0
提示:
0 <= s.length <= 5 * 104
s 由英文字母、数字、符号和空格组成
二、解题思路
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
| #include <iostream> #include <algorithm> #include <string> #include <unordered_set>
using namespace std;
class Solution { public: int lengthOfLongestSubstring(string s) { if (s.size() == 0) return 0; unordered_set<char> lookup; int maxStr = 0; int left = 0; for (int i = 0; i < s.size(); i++) { while (lookup.find(s[i]) != lookup.end()) { lookup.erase(s[left]); left++; } maxStr = max(maxStr, i - left + 1); lookup.insert(s[i]); } return maxStr;
} };
int main() {
Solution S1; vector<char> str; string s = "s = "pwwkew"";
auto n = S1.lengthOfLongestSubstring(s);
for (int i = 0; i < s.size(); i++) { str.push_back(s[i]); }
for (int i = 0; i < str.size(); i++) { cout << str[i] << " "; } cout << endl;
int nums = lengthOfLongestSubstring(str);
cout << "字符串最的长无重复子串的长度为: " << nums << endl;
cout << "无重复子串的长度为: " << n << endl;
return 0; }
|
参考:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/solution/wu-zhong-fu-zi-fu-de-zui-chang-zi-chuan-by-leetc-2/