Inhaltsverzeichnis
Algorithmusbeschreibung
Code-Implementierung
Heim Backend-Entwicklung Python-Tutorial So implementieren Sie den Merge-Sortieralgorithmus in Python

So implementieren Sie den Merge-Sortieralgorithmus in Python

May 21, 2023 am 08:31 AM
python

Algorithmusbeschreibung

Der erste erweiterte Sortieralgorithmus in diesem Abschnitt ist die Zusammenführungssortierung. Das Wort „Merger“ bedeutet „verschmelzen“. Wie der Name schon sagt, handelt es sich beim Zusammenführungssortierungsalgorithmus um einen Algorithmus, der die Sequenz zunächst in Untersequenzen aufteilt, die Untersequenzen sortiert und dann die geordneten Untersequenzen zu einer vollständigen geordneten Sequenz zusammenführt. Es übernahm tatsächlich die Idee des Teilens und Herrschens.

Die durchschnittliche Zeitkomplexität der Zusammenführungssortierung beträgt O(nlgn), die Zeitkomplexität beträgt im besten Fall O(nlgn) und die Zeitkomplexität im schlechtesten Fall beträgt ebenfalls O(nlgn). Seine räumliche Komplexität beträgt O(1). Darüber hinaus ist Merge Sort ein stabiler Sortieralgorithmus.

Am Beispiel der aufsteigenden Sortierung ist der Ablauf des Zusammenführungsalgorithmus in Abbildung 2-21 dargestellt.

Das ursprüngliche Array ist ein ungeordnetes Array mit 8 Zahlen. Nach einer Operation wird das Array mit 8 Zahlen in zwei ungeordnete Arrays mit 4 Zahlen aufgeteilt. Jede Operation teilt das ungeordnete Array in zwei Hälften, bis alle kleinsten Unterarrays nur noch ein Element enthalten. Wenn das Array nur ein Element enthält, muss das Array geordnet sein. Dann beginnt das Programm, alle zwei kleinen geordneten Arrays zu einem großen geordneten Array zusammenzuführen. Zuerst werden zwei Arrays mit einer Zahl zu einem Array mit zwei Zahlen zusammengeführt, dann werden zwei Arrays mit zwei Zahlen zu einem Array mit vier Zahlen zusammengeführt und schließlich werden zwei Arrays mit zwei Zahlen zu einem Array mit acht Zahlen zusammengeführt. Wenn alle geordneten Arrays kombiniert werden, wird das am längsten gebildete geordnete Array sortiert.

So implementieren Sie den Merge-Sortieralgorithmus in Python

Code-Implementierung

Sortiercode zusammenführen:

  #归并排序
nums = [5,3,6,4,1,2,8,7]
def MergeSort(num):
  if(len(num)<=1):        #递归边界条件
   return num         #到达边界时返回当前的子数组
  mid = int(len(num)/2)      #求出数组的中位数
  llist,rlist = MergeSort(num[:mid]),MergeSort(num[mid:])#调用函数分别为左右数组排序
  result = []
  i,j = 0,0
  while i < len(llist) and j < len(rlist): #while循环用于合并两个有序数组
   if rlist[j]<llist[i]:
     result.append(rlist[j])
     j += 1
   else:
     result.append(llist[i])
     i += 1
  result += llist[i:]+rlist[j:]  #把数组未添加的部分加到结果数组末尾
  return result         #返回已排序的数组
print(MergeSort(nums))
Nach dem Login kopieren

Führen Sie das Programm aus und das Ausgabeergebnis lautet:

[1,2,3,4,5,6,7,8]
Nach dem Login kopieren

In der Funktion MergeSort() müssen zunächst die Randbedingungen beurteilt werden. Wenn ein Array, das nur ein Element enthält, als Funktionsparameter übergeben wird, existiert nur das Element im Array, sodass das Array seine Mindestgröße erreicht hat. Sobald Sie mit der Aufgabe der rekursiven Zerlegung eines Arrays fertig sind, bringen Sie das zerlegte Array einfach auf die vorherige Rekursionsebene zurück.

Wenn die Länge des unsortierten Arrays immer noch größer als 1 ist, verwenden Sie die Variable mid, um den mittleren Index des Arrays zu speichern und das unsortierte Array links und rechts in zwei Unterarrays aufzuteilen. Erstellen Sie dann zwei neue Arrays, um die sortierten linken und rechten Subarrays zu speichern. Hier wird die Idee der Rekursion verwendet. Wir stellen uns die Funktion MergeSort() nur als eine Funktion vor, die eine Liste sortiert, obwohl innerhalb der Funktion MergeSort() auch die Funktion selbst aufgerufen werden kann, um zwei Unterarrays zu sortieren.

Verwenden Sie anschließend eine While-Schleife, um die beiden bereits sortierten Arrays zusammenzuführen. Da die relative Größe der Elemente in den beiden Arrays nicht bestimmt werden kann, verwenden wir zwei Variablen, i und j, um die Positionen der Elemente zu markieren, die darauf warten, im linken Sub-Array bzw. im rechten Sub-Array hinzugefügt zu werden. Wenn die while-Schleife endet, verbleiben am Ende eines Subarrays möglicherweise einige größte Elemente, die nicht zur Ergebnisliste hinzugefügt wurden. Die Anweisung result+=llist[i:]+rlist[j:] dient daher dazu, diese Elemente zu verhindern davor, vermisst zu werden. Nachdem die Array-Zusammenführung abgeschlossen ist, gibt die Funktion ein geordnetes Array aus.

Das obige ist der detaillierte Inhalt vonSo implementieren Sie den Merge-Sortieralgorithmus in Python. 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)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen 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)

Wie kann man Node.js oder Python -Dienste in Lampenarchitektur effizient integrieren? Wie kann man Node.js oder Python -Dienste in Lampenarchitektur effizient integrieren? Apr 01, 2025 pm 02:48 PM

Viele Website -Entwickler stehen vor dem Problem der Integration von Node.js oder Python Services unter der Lampenarchitektur: Die vorhandene Lampe (Linux Apache MySQL PHP) Architekturwebsite benötigt ...

Was ist der Grund, warum Pipeline persistente Speicherdateien bei der Verwendung von Scapy Crawler nicht geschrieben werden kann? Was ist der Grund, warum Pipeline persistente Speicherdateien bei der Verwendung von Scapy Crawler nicht geschrieben werden kann? Apr 01, 2025 pm 04:03 PM

Bei der Verwendung von Scapy Crawler kann der Grund, warum Pipeline persistente Speicherdateien nicht geschrieben werden kann? Diskussion beim Lernen, Scapy Crawler für Data Crawler zu verwenden, begegnen Sie häufig auf eine ...

Was ist der Grund, warum der Python -Prozesspool gleichzeitige TCP -Anfragen behandelt und den Kunden dazu bringt, stecken zu bleiben? Was ist der Grund, warum der Python -Prozesspool gleichzeitige TCP -Anfragen behandelt und den Kunden dazu bringt, stecken zu bleiben? Apr 01, 2025 pm 04:09 PM

Python Process Pool verarbeitet gleichzeitige TCP -Anfragen, die dazu führen, dass der Client stecken bleibt. Bei der Verwendung von Python für die Netzwerkprogrammierung ist es entscheidend, gleichzeitige TCP -Anforderungen effizient zu verarbeiten. ...

Wie kann ich die ursprünglichen Funktionen betrachten, die von Python Functools.Partial Object in intern eingekapselt sind? Wie kann ich die ursprünglichen Funktionen betrachten, die von Python Functools.Partial Object in intern eingekapselt sind? Apr 01, 2025 pm 04:15 PM

Erforschen Sie tief die Betrachtungsmethode von Python Functools.Partialial Object in functools.Partial mit Python ...

Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Apr 01, 2025 pm 05:09 PM

Lösung für Erlaubnisprobleme beim Betrachten der Python -Version in Linux Terminal Wenn Sie versuchen, die Python -Version in Linux Terminal anzuzeigen, geben Sie Python ein ...

Python Cross-Platform Desktop-Anwendungsentwicklung: Welche GUI-Bibliothek ist die beste für Sie? Python Cross-Platform Desktop-Anwendungsentwicklung: Welche GUI-Bibliothek ist die beste für Sie? Apr 01, 2025 pm 05:24 PM

Auswahl der Python-plattformübergreifenden Desktop-Anwendungsentwicklungsbibliothek Viele Python-Entwickler möchten Desktop-Anwendungen entwickeln, die sowohl auf Windows- als auch auf Linux-Systemen ausgeführt werden können ...

Python Hourglass Graph Drawing: Wie vermeiden Sie variable undefinierte Fehler? Python Hourglass Graph Drawing: Wie vermeiden Sie variable undefinierte Fehler? Apr 01, 2025 pm 06:27 PM

Erste Schritte mit Python: Hourglas -Grafikzeichnung und Eingabeüberprüfung In diesem Artikel wird das Problem der Variablendefinition gelöst, das von einem Python -Anfänger im Hourglass -Grafikzeichnungsprogramm auftritt. Code...

Wie kann ich große Produktdatensätze in Python effizient zählen und sortieren? Wie kann ich große Produktdatensätze in Python effizient zählen und sortieren? Apr 01, 2025 pm 08:03 PM

Datenkonvertierung und Statistik: Effiziente Verarbeitung großer Datensätze In diesem Artikel werden ausführlich das Umwandeln einer Datenliste in eine andere enthält ...

See all articles