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
| #include <string> #include <unordered_set> #include <algorithm> using std::string; using std::unordered_set;
class Solution { public: int lengthOfLongestSubstring(string s) { int i = 0, j = 0; int n = s.size(); unordered_set<char> uset; int len = 0; for (j = 0; j < n; j++) { if (uset.count(s[j])) { len = std::max(len, (int)uset.size()); while (s[i] != s[j]) { uset.erase(s[i]); i++; } if (s[i] == s[j]) { uset.erase(s[i]); i++; } } uset.insert(s[j]); } return std::max(len, (int)uset.size()); } };
|