Heim >Java >javaLernprogramm >Längster Teilstring ohne sich wiederholende Zeichen

Längster Teilstring ohne sich wiederholende Zeichen

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-09-24 06:21:48723Durchsuche

Longest substring without repeating characters

Problem

Beim Brute-Force-Ansatz werden alle möglichen Teilzeichenfolgen der gegebenen Zeichenfolge erstellt und herausgefunden, welche die längste Teilzeichenfolge ohne das sich wiederholende Zeichen ist. Dies führt zu TC:O(n^2)

Optimaler Ansatz:
TC: O(n)
SC: O(256), zur Verwendung von int[] der Größe 256

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;
    }
}

Das obige ist der detaillierte Inhalt vonLängster Teilstring ohne sich wiederholende Zeichen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn