首頁  >  文章  >  Java  >  沒有重複字元的最長子串

沒有重複字元的最長子串

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-09-24 06:21:48709瀏覽

Longest substring without repeating characters

問題

暴力方法將涉及創建給定字串的所有可能的子字串,並找出哪個是最長的沒有重複字元的子字串。這將導致 TC:O(n^2)

最佳方法:
TC:O(n)
SC : O(256),用於使用大小為 256 的 int[]

class Solution {
    public int lengthOfLongestSubstring(String s) {
        int hash[] = new int[256];// size of all the ascii characters
        Arrays.fill(hash,-1); // -1 to indicate these indexes don't have any character visited already
        int left =0,right =0;
        int max = 0;
        while(right<s.length()){
            char  c = s.charAt(right);
            if(hash[c]!=-1){// means the character has been seen in the past
                if(hash[c]>=left){// if the index of the character seen in the past is after the left pointer, then left pointer should be updated, to avoid duplicate in the window of substring
                    left  = hash[c] + 1;// has to be 1 index after the index of last seen duplicate character
                }
            }
            max = Integer.max(max, right-left+1);// keep track of mas window substring
            hash[c]  = right;// update the character last seen index in hash
            right++;
        }
        return max;
    }
}

以上是沒有重複字元的最長子串的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn