Heim >Backend-Entwicklung >PHP-Tutorial >PHP implementiert mehrere gängige Sortieralgorithmen

PHP implementiert mehrere gängige Sortieralgorithmen

小云云
小云云Original
2018-03-10 13:34:427080Durchsuche

Austauschsortierung: Die Grundidee der Austauschsortierung besteht darin, die Schlüsselwerte zweier Datensätze zu vergleichen. Wenn die Schlüsselwerte der beiden Datensätze in umgekehrter Reihenfolge sind, werden die beiden Datensätze ausgetauscht, sodass der Datensatz entsteht mit dem kleineren Schlüsselwert wird in die entgegengesetzte Richtung verschoben, und Datensätze mit größeren Schlüsselwerten werden an das Ende der Sequenz verschoben.




1. Blasensortierung

Einführung:

Bubble Sort (Bubble Sort, übersetzt aus Taiwan als: Bubble Sort oder Blasensortierung) ist ein einfacher Sortieralgorithmus . Es durchläuft wiederholt die zu sortierende Sequenz, vergleicht jeweils zwei Elemente und vertauscht sie, wenn sie in der falschen Reihenfolge sind. Der Besuch des Arrays wird wiederholt, bis kein Austausch mehr erforderlich ist, was bedeutet, dass das Array sortiert wurde. Der Name dieses Algorithmus rührt von der Tatsache her, dass kleinere Elemente durch den Austausch langsam an die Spitze des Arrays „schweben“.

Schritte:

  1. Benachbarte Elemente vergleichen. Wenn das erste größer als das zweite ist, tauschen Sie beide aus.

  2. Machen Sie dasselbe für jedes Paar benachbarter Elemente, vom ersten Paar am Anfang bis zum letzten Paar am Ende. Zu diesem Zeitpunkt sollte das letzte Element die größte Zahl sein.

  3. Wiederholen Sie die obigen Schritte für alle Elemente außer dem letzten.

  4. Wiederholen Sie die obigen Schritte jedes Mal für immer weniger Elemente, bis keine Zahlenpaare mehr zum Vergleichen vorhanden sind.

Blasensortierung ist am einfachsten zu verstehen, aber die zeitliche Komplexität ist ( O(n^2)) ist auch einer der größten. Der Implementierungscode lautet wie folgt:

<br/>
  1. $arr=array(1,43,54,62,21 ,66,32,78,36,76,39); $arr

    )
  2. {

    $len
  3. =

    count

    (
  4. $arr

    ); //Legen Sie ein leeres Array fest, um auftauchende Blasen zu empfangen

  5. //Diese Ebenenschleife steuert die Anzahl der Runden, die gesprudelt werden müssen

  6. für($i

    =1;
  7. $ i

    60a7055cacaf42ea70c1136185bc5ae6$arr [$k+1])  

  8.         {  

  9.             $tmp=$arr[$k +1];  

  10.             $arr[$k+1] =$arr[$k];  

  11.  $arr[$k]=$tmp; 🎜>

  12.  
  13. zurück

     

    $ arr
  14. ;

  15. } >2. Schnelle Sortierung Einführung: Quick Sort wurde von

    Tony Hall
  16. Ein Sortieralgorithmus entwickelt. Unter durchschnittlichen Umständen erfordert das Sortieren von
  17. n

    Elementen Ο(

    n
  18. log
n

) Vergleiche. Im schlimmsten Fall sind Ο(n2) Vergleiche erforderlich, aber diese Situation ist ungewöhnlich. Tatsächlich ist die schnelle Sortierung normalerweise deutlich schneller als andere

Ο

(n log

n

)-Algorithmen, da ihre innere Schleife in den meisten Architekturen sehr gut implementiert werden kann effizient und in den meisten realen Daten kann die Möglichkeit eines quadratischen Termes die Entwurfsauswahl bestimmen und den Zeitaufwand reduzieren. Schritte:

  1. Wählen Sie ein Element aus der Sequenz aus, das als „Pivot“ bezeichnet wird.

  2. Ordnen Sie die Sequenz neu, alle Elemente Elemente, die kleiner als der Basiswert sind, werden vor der Basis platziert, und alle Elemente, die größer als der Basiswert sind, werden hinter der Basis platziert (die gleiche Anzahl kann auf beiden Seiten platziert werden). Nachdem diese Partition beendet wurde, befindet sich die Basis in der Mitte der Sequenz. Dies wird als Partition -Vorgang bezeichnet.

  3. Rekursiv sortieren Sie das Subarray der Elemente, die kleiner als der Basiswert sind, und das Subarray der Elemente, die größer als der Basiswert sind.

Schnellsortierung ist ebenfalls ein effizienter Sortieralgorithmus, und seine zeitliche Komplexität beträgt ebenfalls O( nlogn). Der Code lautet wie folgt:

  1. function quick_sort($arr ) { 

  2. //Bestimmen Sie zunächst, ob Sie fortfahren müssen

  3.  $length = count($arr);

  4.                      ) {

  5.  zurück $arr

  6. }  

  7.                                                                                      🎜> 

  8.  

    //Wählen Sie ein Lineal aus 

  9.  

    //Wählen Sie das erste Element aus  

  10.  

    $base_num = $arr [0];

  11. //Alle Elemente außer dem Lineal durchlaufen und entsprechend ihrer Größe in zwei Arrays einteilen

  12. //Zwei Arrays initialisieren

  13. $left_array = array();// kleiner als das Lineal

  14. $right_array = array ();// größer als das Lineal

  15.  für($i=1; $i55cf87c727ded8809c5562f1ddc4bbc0 $arr[$i]) {

  16. 🎜>

  17. $left_array[] = $arr[$i]; {

  18.                                    

  19.  $right_array[] = $arr[$i];

  20. >

  21. //Dann Führen Sie den gleichen Sortiervorgang für das linke bzw. rechte Array aus

  22. // Rufen Sie diese Funktion rekursiv auf und zeichnen Sie sie auf das Ergebnis

  23.  $left_array

    = quick_sort(
  24. $ left_array

    );  $right_array

    = quick_sort(
  25. $right_array

    ); //Füge das linke und das rechte Lineal zusammen

  26.  return array_merge($left_array , array($base_num), $right_array);

  27. }

Sortieren auswählen

Die Auswahlsortierung umfasst zwei Arten, nämlich die direkte Auswahlsortierung und die Heap-Sortierung. Die Grundidee der Auswahlsortierung besteht darin, dass jedes Mal n- i+ Wählen Sie den Datensatz mit dem kleinsten Schlüsselwert unter 1 (i=1,2,3,...,n-1) Datensätzen als i-ten Datensatz in der geordneten Reihenfolge aus

3. Auswahlsortierung

Einführung:

Auswahlsortierung ist ein einfacher und intuitiver Sortieralgorithmus. So funktioniert es. Suchen Sie zunächst das kleinste Element in der unsortierten Sequenz und speichern Sie es am Anfang der sortierten Sequenz. Suchen Sie dann weiterhin das kleinste Element aus den verbleibenden unsortierten Elementen und fügen Sie es dann am Ende der sortierten Sequenz ein. Und so weiter, bis alle Elemente sortiert sind.


Die Auswahlsortierung ist ebenfalls relativ einfach zu verstehen und die zeitliche Komplexität beträgt ebenfalls O (n ^ 2). Der Implementierungscode lautet wie folgt:

<br/>


[php]einfach anzeigenkopieren


  1. Funktion select_sort($arr) {

  2. //Implementierungsidee: Die Doppelschleife ist abgeschlossen, die äußere Schicht steuert die Anzahl der Runden und den aktuellen Mindestwert. Die Anzahl der von der inneren Ebene gesteuerten Vergleiche

  3. //$i Die Position des aktuellen Minimalwerts , die am Vergleich teilnehmen müssen Elemente

  4. =0, $len =count($arr) ; $i2451503426ffe001a0d0b894355cf867= A[i]. Bei der nicht absteigenden Sortierung eines Arrays muss ein großer Root-Heap verwendet werden, da gemäß den Anforderungen eines großen Root-Heaps der Maximalwert oben im Heap liegen muss.

    Sortiereffekt:


    堆排序是一种高效的排序算法,它的时间复杂度是O(nlogn)。原理是:先把数组转为一个最大堆,然后把第一个元素跟第i元素交换,然后把剩下的i-1个元素转为最大堆,然后再把第一个元素与第i-1个元素交换,以此类推。实现代码如下:

    function heapSort($arr) {
        $len = count($arr);    // 先建立最大堆
        for ($i = floor(($len - 1) / 2); $i >= 0; $i--) {        $s = $i;        $childIndex = $s * 2 + 1;        while ($childIndex < $len) {            // 在父、左子、右子中 ,找到最大的
                if ($childIndex + 1 < $len && $arr[$childIndex] < $arr[$childIndex + 1]) $childIndex++;            if ($arr[$s] < $arr[$childIndex]) {                $t = $arr[$s];                $arr[$s] = $arr[$childIndex];                $arr[$childIndex] = $t;                $s = $childIndex;                $childIndex = $childIndex * 2 + 1;
                } else {                break;
                }
            }
        }    // 从最后一个元素开始调整
        for ($i = $len - 1; $i > 0; $i--) {        $t = $arr[$i];        $arr[$i] = $arr[0];        $arr[0] = $t;        // 调整第一个元素
            $s = 0;        $childIndex = 1;        while ($childIndex < $i) {            // 在父、左子、右子中 ,找到最大的
                if ($childIndex + 1 < $i && $arr[$childIndex] < $arr[$childIndex + 1]) $childIndex++;            if ($arr[$s] < $arr[$childIndex]) {                $t = $arr[$s];                $arr[$s] = $arr[$childIndex];                $arr[$childIndex] = $t;                $s = $childIndex;                $childIndex = $childIndex * 2 + 1;
                } else {                break;
                }
            }
        }    return $arr;
    }$arr = [3,1,13,5,7,11,2,4,14,9,15,6,12,10,8];
    print_r(bubbleSort($arr));


    插入排序 

    五、插入排序 

    介绍:

    插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

    步骤:

    1. 从第一个元素开始,该元素可以认为已经被排序

    2. 取出下一个元素,在已经排序的元素序列中从后向前扫描

    3. 如果该元素(已排序)大于新元素,将该元素移到下一位置

    4. 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置

    5. 将新元素插入到该位置中

    6. 重复步骤2


    感觉插入排序跟冒泡排序有点相似,时间复杂度也是O(n^2),实现代码如下:


    [php]einfach anzeigenkopieren


    1. function insert_sort($arr) {

    2.  //Unterscheiden Sie, welcher Teil sortiert wurde 

    3.  / /Welches Teil ist nicht sortiert

    4. //Finden Sie eines der Elemente, das sortiert werden muss

    5. //Dieses Element beginnt beim zweiten Element und endet mit dem letzten Element, das sortiert werden muss

    6. //Schleife verwenden, um es zu markieren

    7. //i-Schleife steuert die Elemente, die jedes Mal eingefügt werden müssen. Sobald die Elemente gesteuert werden, die eingefügt werden müssen,

    8. //Indirekt wurde das Array in 2 Teile geteilt, der Index ist kleiner als der aktuelle (linke), es ist die sortierte Reihenfolge

    9.  for($i=1, $len=count($arr); $i< ;$len; $i++) {

    10.  //Erhalten Sie den aktuellen Elementwert, der verglichen werden muss.

    11. [$i]; Vergleichen und einfügen

    12. 🎜> =$i

      -1;
    13. $j

      >=0;$j --) {

    14. //$arr[$i];//Elemente, die eingefügt werden müssen; $arr[$j];//Elemente, die verglichen werden müssen

    15.                                            >]) {                                                                                           Elemente werden mit den vorherigen Elementen vertauscht

      🎜>$j
    16. +1] =

      $arr[$j

      ];
    17.                                                                                                                                                                                                         

    18. $arr
    19. [ $j] = $tmp;

    20.             } else {  

    21.                 //如果碰到不需要移动的元素  

    22.            //由于是已经排序好是数组,则前面的就不需要再次比较了。  

    23.                 break;  

    24.             }  

    25.         }  

    26.     }  

    27.     //将这个元素 插入到已经排序好的序列内。  

    28.     //返回  

    29.     return $arr;  

    30. }  

    <br/>

    六、希尔排序 

    介绍:

    希尔排序,也称递减增量排序算法,是插入排序的一种高速而稳定的改进版本。

    希尔排序是基于插入排序的以下两点性质而提出改进方法的:

    1、插入排序在对几乎已经排好序的数据操作时, 效率高, 即可以达到线性排序的效率

    2、但插入排序一般来说是低效的, 因为插入排序每次只能将数据移动一位>

    排序效果:


    希尔排序其实可以理解是插入排序的一个优化版,它的效率跟增量有关,增量要取多少,根据不同的数组是不同的,所以希尔排序是一个不稳定的排序算法,它的时间复杂度为O(nlogn)到O(n^2)之间,实现代码如下:

    function shellSort($arr) {
        $len = count($arr);    $stepSize = floor($len / 2);    while ($stepSize >= 1) {        for ($i = $stepSize; $i < $len; $i++) {            if ($arr[$i] < $arr[$i - $stepSize]) {                $t = $arr[$i];                $j = $i - $stepSize;                while ($j >= 0 && $t < $arr[$j]) {                    $arr[$j + $stepSize] = $arr[$j];                    $j -= $stepSize;
                    }                $arr[$j + $stepSize] = $t;
                }
            }        // 缩小步长,再进行插入排序
            $stepSize = floor($stepSize / 2);
        }    return $arr;
    }$arr = [3,1,13,5,7,11,2,4,14,9,15,6,12,10,8];
    print_r(bubbleSort($arr));


    七、归并排序 

    介绍:

    归并排序(Merge sort,台湾译作:合并排序)是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(pide and Conquer)的一个非常典型的应用

    步骤:

    1. 申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列

    2. 设定两个指针,最初位置分别为两个已经排序序列的起始位置

    3. 比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置

    4. 重复步骤3直到某一指针达到序列尾

    5. 将另一序列剩下的所有元素直接复制到合并序列尾

    排序效果:


    归并排序的时间复杂度也是O(nlogn)。原理是:对于两个排序好的数组,分别遍历这两个数组,获取较小的元素插入新的数组中,那么,这么新的数组也会是排序好的。代码如下:

    我们先来看看主函数部分:

    //交换函数function swap(array &$arr,$a,$b){
        $temp = $arr[$a];    $arr[$a] = $arr[$b];    $arr[$b] = $temp;
    }//归并算法总函数function MergeSort(array &$arr){
        $start = 0;    $end = count($arr) - 1;
        MSort($arr,$start,$end);
    }

    在总函数中,我们只调用了一个 MSort() 函数,因为我们要使用递归调用,所以将 MSort() 封装起来。

    下面我们来看看 MSort() 函数:

    function MSort(array &$arr,$start,$end){    //当子序列长度为1时,$start == $end,不用再分组    if($start < $end){        $mid = floor(($start + $end) / 2);	//将 $arr 平分为 $arr[$start - $mid] 和 $arr[$mid+1 - $end]        MSort($arr,$start,$mid);			//将 $arr[$start - $mid] 归并为有序的$arr[$start - $mid]        MSort($arr,$mid + 1,$end);			//将 $arr[$mid+1 - $end] 归并为有序的 $arr[$mid+1 - $end]        Merge($arr,$start,$mid,$end);       //将$arr[$start - $mid]部分和$arr[$mid+1 - $end]部分合并起来成为有序的$arr[$start - $end]
        }
    }

    上面的 MSort() 函数实现将数组分半再分半(直到子序列长度为1),然后将子序列合并起来。

    现在是我们的归并操作函数 Merge() :

    //归并操作function Merge(array &$arr,$start,$mid,$end){
        $i = $start;    $j=$mid + 1;    $k = $start;    $temparr = array();    while($i!=$mid+1 && $j!=$end+1)
        {       if($arr[$i] >= $arr[$j]){           $temparr[$k++] = $arr[$j++];
           }       else{           $temparr[$k++] = $arr[$i++];
           }
        }    //将第一个子序列的剩余部分添加到已经排好序的 $temparr 数组中
        while($i != $mid+1){        $temparr[$k++] = $arr[$i++];
        }    //将第二个子序列的剩余部分添加到已经排好序的 $temparr 数组中
        while($j != $end+1){        $temparr[$k++] = $arr[$j++];
        }    for($i=$start; $i<=$end; $i++){        $arr[$i] = $temparr[$i];
        }
    }

    到了这里,我们的归并算法就完了。我们调用试试:

    $arr = array(9,1,5,8,3,7,4,6,2);
    MergeSort($arr);
    var_dump($arr);

    相关推荐:

    php冒泡、选择、插入和快速排序算法分享

    PHP多维数组排序算法分析

    PHP排序算法系列之直接选择排序详解

Das obige ist der detaillierte Inhalt vonPHP implementiert mehrere gängige Sortieralgorithmen. 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