Heim Backend-Entwicklung Python-Tutorial Detaillierte Einführung in die Implementierungsschritte des Merge-Sort-Algorithmus in der Python-Programmierung

Detaillierte Einführung in die Implementierungsschritte des Merge-Sort-Algorithmus in der Python-Programmierung

Mar 06, 2017 pm 01:27 PM

Grundidee: Die Zusammenführungssortierung ist eine typische Divide-and-Conquer-Idee, die eine ungeordnete Liste in zwei Teile teilt, dann jede Teilsequenz erneut in zwei Teile teilt und so lange fortfährt, bis sie nicht mehr geteilt werden kann. Dann beginnt der Zusammenführungsprozess, bei dem die Elemente jeder Teilsequenz mit einer anderen Teilsequenz verglichen werden, die kleinen Elemente nacheinander zur Zusammenführung in die Ergebnissequenz eingefügt werden und schließlich die Zusammenführungssortierung abgeschlossen wird.

Zusammenführungsprozess:

Wenden Sie Platz an, sodass seine Größe der Summe der beiden sortierten Sequenzen entspricht. Dieser Platz wird zum Speichern der zusammengeführten Sequenz verwendet
Setzen Sie zwei Zeiger, die Anfangspositionen sind die Anfangspositionen der beiden sortierten Sequenzen.
Vergleichen Sie die Elemente, auf die die beiden Zeiger zeigen, wählen Sie das relativ kleine Element aus, legen Sie es in den Zusammenführungsbereich und bewegen Sie den Zeiger dorthin die nächste Position
Wiederholen Sie Schritt 3, bis ein bestimmter Zeiger das Ende der Sequenz erreicht
Kopieren Sie alle verbleibenden Elemente der anderen Sequenz direkt an das Ende der zusammengeführten Sequenz
Die obige Aussage ist eine theoretische Aussage. Hier ein praktisches Beispiel zur Veranschaulichung:

Zum Beispiel ein ungeordnetes Array

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

Zerlegen Sie das Array zunächst rekursiv bis:

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

Dann starten Sie die Zusammenführungssortierung, ebenfalls auf rekursive Weise:

Zusammenführen und zwei nach zwei sortieren, erhalten Sie:

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

Im vorherigen Schritt wurde es tatsächlich auf die gleiche Weise wie in diesem Schritt zusammengeführt, aber da jede Liste eine Nummer enthält, kann der Vorgang nicht vollständig angezeigt werden . Der Prozess kann unten vollständig dargestellt werden.

Anfänglich:

 a = [2,6] b = [1,3] c = []
Nach dem Login kopieren

Schritt 1, nehmen Sie nacheinander eine Zahl aus a, b heraus: 2, 1, vergleichen Sie die Größe und Geben Sie c ein und löschen Sie die Nummer aus der ursprünglichen Liste. Das Ergebnis ist:

a = [2,6] b = [3] c = [1]
Nach dem Login kopieren

Schritt 2, fahren Sie mit a, b fort Zahl, das heißt, wiederholen Sie die obigen Schritte, dieses Mal ist es: 2,3. Geben Sie sie in c ein und löschen Sie die Zahl aus der ursprünglichen Liste. Das Ergebnis ist:

a = [6] b = [3] c = [1,2]
Nach dem Login kopieren

Schritt 3, wiederholen Sie die vorherigen Schritte, das Ergebnis ist:

a = [6] b = [] c = [1,2,3]
Nach dem Login kopieren

Der letzte Schritt ist hänge 6 an c an, das Ergebnis ist:

a = [] b = [] c = [1,2,3,6]
Nach dem Login kopieren

Durch wiederholtes Anwenden des obigen Prozesses wird die Zusammenführung von [1,2,3,6] und [7] ist erreicht

Endlich das Sortierergebnis erhalten

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

In diesem Artikel werden drei Python-Implementierungsmethoden aufgeführt:

Methode 1: Übersetzen Sie den oben beschriebenen Prozess, etwas ungeschickt

#! /usr/bin/env python
#coding:utf-8

def merge_sort(seq):
 if len(seq) ==1:
 return seq
 else:
 middle = len(seq)/2
 left = merge_sort(seq[:middle])
 right = merge_sort(seq[middle:])

 i = 0 #left 计数
 j = 0 #right 计数
 k = 0 #总计数

 while i < len(left) and j < len(right):
  if left[i] < right [j]:
  seq[k] = left[i]
  i +=1
  k +=1
  else:
  seq[k] = right[j]
  j +=1
  k +=1

 remain = left if i<j else right
 r = i if remain ==left else j

 while r<len(remain):
  seq[k] = remain[r]
  r +=1
  k +=1

 return seq
Nach dem Login kopieren

Methode 2: In Bezug auf das Nehmen von Werten in der Reihenfolge anwenden Ohne die list.pop()-Methode ist der Code kompakter und prägnanter

#! /usr/bin/env python
#coding:utf-8


def merge_sort(lst): #此方法来自维基百科

 if len(lst) <= 1:
 return lst

 def merge(left, right):
 merged = []

 while left and right:
  merged.append(left.pop(0) if left[0] <= right[0] else right.pop(0))

 while left:
  merged.append(left.pop(0))

 while right:
  merged.append(right.pop(0))

 return merged

 middle = int(len(lst) / 2) 
 left = merge_sort(lst[:middle])
 right = merge_sort(lst[middle:])
 return merge(left, right)
Nach dem Login kopieren

Methode 3: Es stellt sich heraus Diese Zusammenführung ist im Python-Modul heapq vorgesehen. Für die Sortiermethode importieren Sie einfach die zerlegten Ergebnisse in diese Methode.

#! /usr/bin/env python
#coding:utf-8


from heapq import merge

def merge_sort(seq):
 if len(seq) <= 1:
 return m
 else:  
 middle = len(seq)/2
 left = merge_sort(seq[:middle])
 right = merge_sort(seq[middle:])
 return list(merge(left, right))  #heapq.merge()

if __name__=="__main__":
 seq = [1,3,6,2,4]
 print merge_sort(seq)
Nach dem Login kopieren

Eine ausführlichere Einführung in die Implementierungsschritte des Merge-Sort-Algorithmus in der Python-Programmierung finden Sie auf der chinesischen PHP-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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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 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 ...

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden? Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden? Apr 02, 2025 am 07:18 AM

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer -Anfänger für Programmierungen? Wenn Sie nur 10 Stunden Zeit haben, um Computer -Anfänger zu unterrichten, was Sie mit Programmierkenntnissen unterrichten möchten, was würden Sie dann beibringen ...

Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet? Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet? Apr 02, 2025 am 07:15 AM

Wie kann man nicht erkannt werden, wenn Sie Fiddlereverywhere für Man-in-the-Middle-Lesungen verwenden, wenn Sie FiddLereverywhere verwenden ...

Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Apr 01, 2025 pm 11:15 PM

Bei der Verwendung von Pythons Pandas -Bibliothek ist das Kopieren von ganzen Spalten zwischen zwei Datenrahmen mit unterschiedlichen Strukturen ein häufiges Problem. Angenommen, wir haben zwei Daten ...

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Apr 01, 2025 pm 10:51 PM

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen an? Uvicorn ist ein leichter Webserver, der auf ASGI basiert. Eine seiner Kernfunktionen ist es, auf HTTP -Anfragen zu hören und weiterzumachen ...

Wie erstelle ich dynamisch ein Objekt über eine Zeichenfolge und rufe seine Methoden in Python auf? Wie erstelle ich dynamisch ein Objekt über eine Zeichenfolge und rufe seine Methoden in Python auf? Apr 01, 2025 pm 11:18 PM

Wie erstellt in Python ein Objekt dynamisch über eine Zeichenfolge und ruft seine Methoden auf? Dies ist eine häufige Programmieranforderung, insbesondere wenn sie konfiguriert oder ausgeführt werden muss ...

Wie löste ich Berechtigungsprobleme bei der Verwendung von Python -Verssionsbefehl im Linux Terminal? Wie löste ich Berechtigungsprobleme bei der Verwendung von Python -Verssionsbefehl im Linux Terminal? Apr 02, 2025 am 06:36 AM

Verwenden Sie Python im Linux -Terminal ...

See all articles