suchen
HeimJavajavaLernprogrammSo implementieren Sie den Zählsortieralgorithmus mit Java

So implementieren Sie den Zählsortieralgorithmus mit Java

So implementieren Sie den Zählsortieralgorithmus in Java

Die Zählsortierung ist ein Sortieralgorithmus ohne Vergleich. Seine Hauptidee besteht darin, zu zählen, wie oft jedes Element im Array erscheint, und das Element dann an der richtigen Position zu platzieren basierend auf der Häufigkeit, mit der es erscheint. Die zeitliche Komplexität der Zählsortierung beträgt O(n+k), wobei n die Länge der zu sortierenden Sequenz und k der Bereich des größten Elements in der zu sortierenden Sequenz ist.

In Java können wir das folgende Codebeispiel verwenden, um den Zählsortieralgorithmus zu implementieren:

public class CountingSort {
    public static void countingSort(int[] array) {
        int n = array.length;
        
        // 找到待排序序列中的最大值
        int max = array[0];
        for (int i = 1; i < n; i++) {
            if (array[i] > max) {
                max = array[i];
            }
        }
        
        // 创建一个计数数组,并初始化为0
        int[] count = new int[max + 1];
        for (int i = 0; i <= max; i++) {
            count[i] = 0;
        }
        
        // 统计每个元素在待排序序列中出现的次数
        for (int i = 0; i < n; i++) {
            count[array[i]]++;
        }
        
        // 根据计数数组构建有序序列
        int index = 0;
        for (int i = 0; i <= max; i++) {
            while (count[i] > 0) {
                array[index] = i;
                index++;
                count[i]--;
            }
        }
    }
    
    public static void main(String[] args) {
        int[] array = {9, 1, 5, 3, 7, 3, 8, 2, 6};
        
        System.out.println("排序前:");
        for (int num : array) {
            System.out.print(num + " ");
        }
        System.out.println();
        
        countingSort(array);
        
        System.out.println("排序后:");
        for (int num : array) {
            System.out.print(num + " ");
        }
        System.out.println();
    }
}

Im obigen Code suchen wir zuerst den Maximalwert in der zu sortierenden Sequenz, erstellen dann ein Zählarray und fügen die Zahl hinzu Anzahl der Vorkommen jedes Elements. Die Statistiken befinden sich im Zählarray. Als nächstes erstellen wir eine geordnete Sequenz basierend auf dem Zählarray. Die spezifische Operation besteht darin, die Elemente im Zählarray in die Sequenz einzufügen, die entsprechend der Anzahl der Vorkommen sortiert werden soll. Wenn wir schließlich die countingSort-Methode aufrufen und die geordnete Sequenz drucken, können wir die Ergebnisse der Zählsortierung sehen.

Es ist zu beachten, dass die Zählsortierung bestimmte Einschränkungen hinsichtlich des Bereichs der zu sortierenden Elemente in der Sequenz hat und nur auf nichtnegative Ganzzahlsequenzen anwendbar ist. Wenn die zu sortierende Sequenz negative Zahlen oder Elemente anderer Datentypen enthält, ist eine entsprechende Verarbeitung erforderlich, bevor der Zählsortieralgorithmus verwendet werden kann.

Das obige ist der detaillierte Inhalt vonSo implementieren Sie den Zählsortieralgorithmus mit Java. 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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

PHPStorm Mac-Version

PHPStorm Mac-Version

Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung