Heim Backend-Entwicklung C#.Net-Tutorial So schreiben Sie einen Heap-Sortieralgorithmus mit C#

So schreiben Sie einen Heap-Sortieralgorithmus mit C#

Sep 19, 2023 am 08:45 AM
编写 c# 堆排序

So schreiben Sie einen Heap-Sortieralgorithmus mit C#

So schreiben Sie mit C# einen Heap-Sortieralgorithmus

Heap Sort ist ein Sortieralgorithmus, der auf einem vollständigen binären Heap basiert und dessen zeitliche Komplexität O(nlogn) beträgt. In diesem Artikel schreiben wir den Heap-Sortieralgorithmus mit C# und stellen detaillierte Codebeispiele bereit.

  1. Erstellen Sie einen Heap

Im Heap-Sortieralgorithmus müssen Sie zunächst einen Max-Heap (oder Min-Heap) erstellen. Die Eigenschaft des Max-Heaps besteht darin, dass der Wert des übergeordneten Knotens größer oder gleich dem Wert seines untergeordneten Knotens ist, während für den Min-Heap das Gegenteil gilt.

Um einen maximalen Heap zu erstellen, können wir ein Array verwenden, um den Heap darzustellen. Die Knoten des Heaps sind hierarchisch angeordnet. Bei einem gegebenen Knotenindex i können wir die Indizes seiner übergeordneten und untergeordneten Knoten wie folgt ermitteln:

  • Index des übergeordneten Knotens = (i - 1) / 2
  • Index des linken untergeordneten Knotens = 2 * i + 1
  • Rechter untergeordneter Knoten index = 2 * i + 2

Mit diesen Indizes können wir uns leicht im Heap bewegen und große (oder kleine) Elemente an die Spitze des Heaps schieben.

Hier ist ein Beispielcode zum Implementieren des maximalen Heaps mit C#:

public void BuildMaxHeap(int[] arr, int n, int i)
{
    int largest = i; // 初始化最大元素的索引
    int left = 2 * i + 1; // 左子节点索引
    int right = 2 * i + 2; // 右子节点索引

    // 如果左子节点比父节点大,更新最大元素的索引
    if (left < n && arr[left] > arr[largest])
    {
        largest = left;
    }

    // 如果右子节点比父节点大,更新最大元素的索引
    if (right < n && arr[right] > arr[largest])
    {
        largest = right;
    }

    // 如果最大元素的索引不是父节点的索引,交换父节点和最大元素
    if (largest != i)
    {
        int temp = arr[i];
        arr[i] = arr[largest];
        arr[largest] = temp;

        // 递归地建立最大堆
        BuildMaxHeap(arr, n, largest);
    }
}
Nach dem Login kopieren
  1. Heap-Sortierung

Nachdem wir den maximalen Heap erstellt haben, können wir den Heap-Sortieralgorithmus verwenden, um das Array zu sortieren. Die Idee der Heap-Sortierung besteht darin, das größte Element kontinuierlich am Ende des Arrays auszutauschen und den zu sortierenden Bereich des Arrays zu verringern. Die spezifischen Schritte sind wie folgt:

  • Erstellen Sie den maximalen Heap.
  • Tauschen Sie das oberste Element und das letzte Element des Heaps.
  • Passen Sie den Heap neu an.
  • Wiederholen Sie die obigen Schritte, bis nur noch ein Element im Array vorhanden ist sortiert werden

Das Folgende ist eine Heap-Sortierung mit C#-Beispielcode für:

public void HeapSort(int[] arr)
{
    int n = arr.Length;

    // 构建最大堆
    for (int i = n / 2 - 1; i >= 0; i--)
    {
        BuildMaxHeap(arr, n, i);
    }

    // 交换堆顶元素和末尾元素,并重建最大堆
    for (int i = n - 1; i > 0; i--)
    {
        int temp = arr[0];
        arr[0] = arr[i];
        arr[i] = temp;

        BuildMaxHeap(arr, i, 0);
    }
}
Nach dem Login kopieren
  1. Testcode

Um zu überprüfen, ob unser Heap-Sortieralgorithmus korrekt ist, können wir einen Testcode schreiben, der ein zufällig generiertes Array sortiert und gibt die Ergebnisse zur Überprüfung aus. Das Folgende ist ein Beispiel für einen in C# geschriebenen Heap-Sortier-Testcode:

int[] arr = { 12, 11, 13, 5, 6, 7 };
HeapSort(arr);

Console.WriteLine("排序后的数组:");
foreach (var element in arr)
{
    Console.Write(element + " ");
}
Nach dem Login kopieren
  1. Zusammenfassung

Durch die oben genannten Schritte haben wir erfolgreich einen Heap-Sortieralgorithmus mit C# geschrieben und detaillierte Codebeispiele bereitgestellt. Heap-Sortierung ist ein effizienter Sortieralgorithmus, der in den meisten Fällen eine gute Leistung bietet. Ich hoffe, dieser Artikel hilft Ihnen, den Heap-Sortieralgorithmus zu verstehen und zu implementieren!

Das obige ist der detaillierte Inhalt vonSo schreiben Sie einen Heap-Sortieralgorithmus mit C#. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

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ßer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Active Directory mit C# Active Directory mit C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Active Directory mit C#. Hier besprechen wir die Einführung und die Funktionsweise von Active Directory in C# sowie die Syntax und das Beispiel.

C#-Serialisierung C#-Serialisierung Sep 03, 2024 pm 03:30 PM

Leitfaden zur C#-Serialisierung. Hier besprechen wir die Einführung, die Schritte des C#-Serialisierungsobjekts, die Funktionsweise bzw. das Beispiel.

Zufallszahlengenerator in C# Zufallszahlengenerator in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zum Zufallszahlengenerator in C#. Hier besprechen wir die Funktionsweise des Zufallszahlengenerators, das Konzept von Pseudozufallszahlen und sicheren Zahlen.

C#-Datenrasteransicht C#-Datenrasteransicht Sep 03, 2024 pm 03:32 PM

Leitfaden zur C#-Datenrasteransicht. Hier diskutieren wir die Beispiele, wie eine Datenrasteransicht aus der SQL-Datenbank oder einer Excel-Datei geladen und exportiert werden kann.

Muster in C# Muster in C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Mustern in C#. Hier besprechen wir die Einführung und die drei wichtigsten Arten von Mustern in C# zusammen mit ihren Beispielen und der Code-Implementierung.

Primzahlen in C# Primzahlen in C# Sep 03, 2024 pm 03:35 PM

Leitfaden zu Primzahlen in C#. Hier besprechen wir die Einführung und Beispiele von Primzahlen in C# sowie die Codeimplementierung.

Fakultät in C# Fakultät in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zur Fakultät in C#. Hier diskutieren wir die Einführung in die Fakultät in C# zusammen mit verschiedenen Beispielen und Code-Implementierungen.

Der Unterschied zwischen Multithreading und asynchronem C# Der Unterschied zwischen Multithreading und asynchronem C# Apr 03, 2025 pm 02:57 PM

Der Unterschied zwischen Multithreading und Asynchron besteht darin, dass Multithreading gleichzeitig mehrere Threads ausführt, während asynchron Operationen ausführt, ohne den aktuellen Thread zu blockieren. Multithreading wird für rechenintensive Aufgaben verwendet, während asynchron für die Benutzerinteraktion verwendet wird. Der Vorteil des Multi-Threading besteht darin, die Rechenleistung zu verbessern, während der Vorteil von Asynchron nicht darin besteht, UI-Threads zu blockieren. Die Auswahl von Multithreading oder Asynchron ist von der Art der Aufgabe abhängt: Berechnungsintensive Aufgaben verwenden Multithreading, Aufgaben, die mit externen Ressourcen interagieren und die UI-Reaktionsfähigkeit asynchron verwenden müssen.

See all articles