Heim php教程 PHP开发 Blasensortierung und zwei Optimierungen der Blasensortierung

Blasensortierung und zwei Optimierungen der Blasensortierung

Dec 19, 2016 pm 01:39 PM
冒泡排序

Die Funktionsweise des Blasensortieralgorithmus ist wie folgt: Vergleichen Sie zwei benachbarte Elemente von vorne nach hinten. Wenn das zweite Element kleiner als das erste Element ist, tauschen Sie die beiden Elemente aus, bis es dem letzten Element entspricht ist abgeschlossen, so dass das größte Element am Ende platziert werden kann; durch Wiederholen des Vergleichs (n-1) kann die Sortierung abgeschlossen werden.

---------------- ------ -------------------------------------------- ------ --------

Quicksort-Algorithmus (eine Optimierung der Blasensortierung):

1) Legen Sie zwei Variablen i und j fest, wenn die Sortierung beginnt: i =0, j=N-1;

2) Verwenden Sie das erste Array-Element als Schlüsseldaten und weisen Sie es dem Schlüssel zu, d. h. key=A[0]; Beginnen Sie mit der Suche nach vorne, d. h. nach vorne (j--), finden Sie den ersten Wert A[j], der kleiner als der Schlüssel ist, und tauschen Sie A[j] und A[i] aus

4) Von i aus rückwärts suchen, also von vorne nach hinten suchen (i++), das erste A[i] finden, das größer als der Schlüssel ist, und A[i] und A[j] austauschen; >5) Wiederholen Sie die Schritte 3 und 4, bis i=j; (In den Schritten 3 und 4 wird kein Wert gefunden, der die Bedingungen erfüllt, d. h. A[j] in 3 ist nicht kleiner als der Schlüssel und A[i] in 4 ist nicht größer als der Schlüssel Wenn Sie die Werte von j und i ändern, sodass j = j-1, i = i + 1 ist, bleiben die Zeigerpositionen von i und j unverändert, bis ein Wert gefunden wird, der die Bedingungen erfüllt Der Austausch muss stattfinden, wenn i+ oder j- abgeschlossen ist; an diesem Punkt endet die Schleife.

                                                                  Überprüfen Sie, ob die Elemente ausgetauscht wurden. Wenn ja, fahren Sie mit dem nächsten Zyklus fort nicht, beenden Sie die Schleife.

Diese Methode zum „Setzen von Flag-Bits“ ist nicht so effizient wie der „Schnellsortierungsalgorithmus“.

---------------- ------ -------------------------------------------- ------ --------

Der C-Sprachcode lautet wie folgt:

Wann n ist groß, Zeitkomplexität sollte verwendet werden. Sortiermethoden mit Grad O(nlog2n): schnelle Sortierung, Heap-Sortierung oder Zusammenführungssortierung.

Schnellsortierung: Sie gilt derzeit als die beste interne Sortiermethode, die auf Vergleich basiert. Wenn die zu sortierenden Schlüsselwörter zufällig verteilt sind, ist die durchschnittliche Zeit der Schnellsortierung am kürzesten 🎜>

/*
** bubble sort
*/ 
void bubble_sort(int *str, int size)
{
     int i = 0, j = 0;
     int tmp = 0;
      
     /*
     ** 进行size-1趟排序;
     */
     for (i = 0; i < size - 1; i++)
     {
         /*
         ** 每排序一趟,将最大的元素沉底。下一趟少比较i次;
         */
 
          for (j = 0; j < size - 1 - i; j++)       
          {
               if (str[j] > str[j + 1])
               {
                    tmp = str[j];
                    str[j] = str[j + 1];
                    str[j + 1] = tmp;
               }
          }
 
     }
}
 
/*
** 优化一:设置一个标志位sign的bubble sort;
*/
 void bubble_sort(int *str, int size)
{
     int i = 0, j = 0;
     int tmp = 0, sign = 0;
      
     for (i = 0; i < size - 1; i++)
     {
          /*
          ** 每趟排序前将sign置为0,如果相邻元素进行了交换则sign>1;
          ** 否则,sign==0,没有进行交换,排序完成,跳出循环;
          */
          flag = 0;
          for (j = 0; j < size - 1 - i; j++)
          {
               if (str[j] > str[j + 1])
               {
                    tmp = str[j];
                    str[j] = str[j + 1];
                    str[j + 1] = tmp;
                    sign++;
               }
          }
          if (0 == sign)
          break;
     }
}
 
 
/*
** 优化二:quick sort;
*/
void quicksort(int *str, int left, int right)
{
     assert(str);
      
     /*
     **如果左边大于或等于右边,则该数组已经排序完成;
     */
     if (left >= right)
     {
          return;
     }
      
     int i = left;
     int j = right;
     int key = str[left];
      
     /*
     **当i=j时,一趟排序完成,将所有数分为一大一小两组;
     */
     while (i < j)
     {
          /*
          **第一次从后向前遍历,遇到第一个比key小的交换两数位置;
          */
          while ((i < j) && (key <= str[j]))
          {
               j--;
          }
          str[i] = str[j];
           
          /*
          **第二次从前向后遍历,遇到第一个比key大的交换两数位置;
          */
          while ((i < j) && (key >= str[i]))
          {
               i++;
          }
          str[j] = str[i];
     }
      
     str[i] = key;
     /*
     **递归调用,完成左、右子序列的排序;
     */
     quicksort(str, left, i - 1);
     quicksort(str, i + 1, right);
}
Nach dem Login kopieren

Weitere Artikel zum Thema Blasensortierung und den beiden Optimierungen der Blasensortierung 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)

Java-Datenstrukturen und -Algorithmen: ausführliche Erklärung Java-Datenstrukturen und -Algorithmen: ausführliche Erklärung May 08, 2024 pm 10:12 PM

Datenstrukturen und Algorithmen sind die Grundlage der Java-Entwicklung. In diesem Artikel werden die wichtigsten Datenstrukturen (wie Arrays, verknüpfte Listen, Bäume usw.) und Algorithmen (wie Sortier-, Such-, Diagrammalgorithmen usw.) ausführlich untersucht. Diese Strukturen werden anhand praktischer Beispiele veranschaulicht, darunter die Verwendung von Arrays zum Speichern von Bewertungen, verknüpfte Listen zum Verwalten von Einkaufslisten, Stapel zum Implementieren von Rekursionen, Warteschlangen zum Synchronisieren von Threads sowie Bäume und Hash-Tabellen für schnelle Suche und Authentifizierung. Wenn Sie diese Konzepte verstehen, können Sie effizienten und wartbaren Java-Code schreiben.

Transformieren Sie Code mit C++-Funktionszeigern: Verbessern Sie Effizienz und Wiederverwendbarkeit Transformieren Sie Code mit C++-Funktionszeigern: Verbessern Sie Effizienz und Wiederverwendbarkeit Apr 29, 2024 pm 06:45 PM

Die Funktionszeigertechnologie kann die Codeeffizienz und Wiederverwendbarkeit verbessern, insbesondere wie folgt: Verbesserte Effizienz: Durch die Verwendung von Funktionszeigern kann wiederholter Code reduziert und der Aufrufprozess optimiert werden. Verbessern Sie die Wiederverwendbarkeit: Funktionszeiger ermöglichen die Verwendung allgemeiner Funktionen zur Verarbeitung verschiedener Daten und verbessern so die Wiederverwendbarkeit von Programmen.

So implementieren Sie den Blasensortierungsalgorithmus in C# So implementieren Sie den Blasensortierungsalgorithmus in C# Sep 19, 2023 am 11:10 AM

So implementieren Sie den Bubble-Sort-Algorithmus in C#. Bubble-Sort ist ein einfacher, aber effektiver Sortieralgorithmus, der ein Array durch mehrmaligen Vergleich benachbarter Elemente und Austausch von Positionen anordnet. In diesem Artikel stellen wir vor, wie der Blasensortierungsalgorithmus mithilfe der C#-Sprache implementiert wird, und stellen spezifische Codebeispiele bereit. Lassen Sie uns zunächst die Grundprinzipien der Blasensortierung verstehen. Der Algorithmus beginnt beim ersten Element des Arrays und vergleicht es mit dem nächsten Element. Wenn das aktuelle Element größer als das nächste Element ist, tauschen Sie ihre Positionen; wenn das aktuelle Element kleiner als das nächste Element ist, behalten Sie es bei

Anleitung zum Schreiben eines benutzerdefinierten Sortieralgorithmus für PHP-Arrays Anleitung zum Schreiben eines benutzerdefinierten Sortieralgorithmus für PHP-Arrays Apr 27, 2024 pm 06:12 PM

Wie schreibe ich einen benutzerdefinierten PHP-Array-Sortieralgorithmus? Blasensortierung: Sortiert ein Array durch Vergleichen und Austauschen benachbarter Elemente. Auswahlsortierung: Wählen Sie jedes Mal das kleinste oder größte Element aus und tauschen Sie es mit der aktuellen Position aus. Einfügungssortierung: Elemente nacheinander in einen geordneten Teil einfügen.

Komplexitätsanalyse verschiedener PHP-Array-Sortieralgorithmen Komplexitätsanalyse verschiedener PHP-Array-Sortieralgorithmen Apr 27, 2024 am 09:03 AM

Komplexität des PHP-Array-Sortieralgorithmus: Blasensortierung: O(n^2) Schnellsortierung: O(nlogn) (Durchschnitt) Zusammenführungssortierung: O(nlogn)

Analysieren Sie Zeitkomplexität und Raumkomplexität in der Go-Sprache Analysieren Sie Zeitkomplexität und Raumkomplexität in der Go-Sprache Mar 27, 2024 am 09:24 AM

Go ist eine immer beliebter werdende Programmiersprache, die einfach zu schreiben, leicht zu lesen und zu warten ist und gleichzeitig fortgeschrittene Programmierkonzepte unterstützt. Zeitkomplexität und Raumkomplexität sind wichtige Konzepte in der Algorithmen- und Datenstrukturanalyse. Sie messen die Ausführungseffizienz und die Speichergröße eines Programms. In diesem Artikel konzentrieren wir uns auf die Analyse der Zeitkomplexität und Raumkomplexität in der Go-Sprache. Zeitkomplexität Zeitkomplexität bezieht sich auf die Beziehung zwischen der Ausführungszeit eines Algorithmus und der Größe des Problems. Die Zeit wird normalerweise in der Big-O-Notation ausgedrückt

Algorithmenauswahl- und Optimierungstechniken bei der Leistungsoptimierung von C++-Funktionen Algorithmenauswahl- und Optimierungstechniken bei der Leistungsoptimierung von C++-Funktionen Apr 23, 2024 pm 06:18 PM

Auswahl des C++-Funktionsleistungsoptimierungsalgorithmus: Wählen Sie effiziente Algorithmen (z. B. schnelle Sortierung, binäre Suche). Optimierungsfähigkeiten: Kleine Funktionen einbinden, Caching optimieren, tiefe Kopien vermeiden und Schleifenabwicklung durchführen. Praktischer Fall: Bei der Suche nach der maximalen Elementposition eines Arrays werden nach der Optimierung die binäre Suche und die Schleifenerweiterung verwendet, was die Leistung erheblich verbessert.

Java-Datenstrukturen und -Algorithmen: Ein praktischer Leitfaden zum Cloud Computing Java-Datenstrukturen und -Algorithmen: Ein praktischer Leitfaden zum Cloud Computing May 09, 2024 am 08:12 AM

Der Einsatz von Datenstrukturen und Algorithmen ist im Cloud Computing von entscheidender Bedeutung, um riesige Datenmengen zu verwalten und zu verarbeiten. Zu den gängigen Datenstrukturen gehören Arrays, Listen, Hash-Tabellen, Bäume und Diagramme. Zu den häufig verwendeten Algorithmen gehören Sortieralgorithmen, Suchalgorithmen und Diagrammalgorithmen. Mithilfe der Leistungsfähigkeit von Java können Entwickler Java-Sammlungen, threadsichere Datenstrukturen und Apache-Commons-Sammlungen verwenden, um diese Datenstrukturen und Algorithmen zu implementieren.

See all articles