Heim > Java > javaLernprogramm > Leetcode-Sortierfarben

Leetcode-Sortierfarben

Linda Hamilton
Freigeben: 2025-01-11 18:03:43
Original
148 Leute haben es durchsucht

Leetcode  Sort Colors

Intuition

Die grundlegende Intuition kommt vom Sortieren.

Ansatz

Im naiven Ansatz können wir das Array mithilfe der integrierten Sortierfunktion sortieren. Die zeitliche Komplexität beträgt O(N*log(N)).

  • Optimieren: Da wir nur drei Zahlen sortieren, können wir das Konzept der Zählsortierung verwenden. Verfolgen Sie die Anzahl der Nullen und Einsen im Array. # Komplexität
  • Zeitliche Komplexität: O(N)

  • Raumkomplexität: O(1)

Code

class Solution {
    public void sortColors(int[] nums) {
        int countZero = 0;
        int countOne  =  0;
        for(int num: nums){
            switch(num){
                case 0:
                    countZero++;
                    break;
                case 1:
                    countOne++;
            }
        }
        int currentIndex = -1;
        while(0<countZero--){
            nums[++currentIndex] = 0;
            // countZero--;
        }
        while(0<countOne--){
            nums[++currentIndex] = 1;
            // countOne--;
        }
        while(currentIndex<nums.length-1){
            nums[++currentIndex] = 2;
        }
    }
}
Nach dem Login kopieren

GitHub-Repo für weitere Lösungen: Git
Leetcode-Profil: Leetcode: devn007

Das obige ist der detaillierte Inhalt vonLeetcode-Sortierfarben. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage