3.11 刷题记录 Longest Substring Without Repeating Characters(3)

 

 滑动窗口问题,找出最大的不重复的字符串

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        unordered_set<char> occ;
        int n = s.size();
        int rk = -1, ans = 0;
        for (int i = 0; i < n; ++i) {
            if (i != 0) {
                occ.erase(s[i - 1]);
            }
            while (rk + 1 < n && !occ.count(s[rk + 1])) {
                occ.insert(s[rk + 1]);
                ++rk;
            }
            ans = max(ans, rk - i + 1);
        }
        return ans;
    }
};

 

posted @ 2021-03-11 19:37  章大佬  阅读(22)  评论(0)    收藏  举报