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
| class Solution { public: int lengthOfLongestSubstring(string s) { int len = s.size(); if (len == 0) return 0; unordered_set<char> usc; int maxlen = 0; int mark = -1; for (int i = 0; i < len; ++i) { if (i != 0) { usc.erase(s[i - 1]); } while (mark + 1 < len && !usc.count(s[mark + 1])) { usc.insert(s[mark + 1]); ++mark; } maxlen = max(maxlen, mark - i + 1); } return maxlen; } };
|