Heim  >  Artikel  >  Backend-Entwicklung  >  PHP-Sortieralgorithmus, Einfügungssortierung

PHP-Sortieralgorithmus, Einfügungssortierung

藏色散人
藏色散人nach vorne
2019-12-09 14:28:573373Durchsuche

Sortierung einfügen

● Die Idee der Einfügungssortierung:

Betrachten Sie ein ungeordnetes Array als zwei Listen, eine geordnete Liste und eine ungeordnete Liste, nehmen Sie jeweils ein einzufügendes Element aus der ungeordneten Liste heraus und fügen Sie es in die geordnete Liste ein, bis die ungeordnete Liste leer ist und die Sortierung abgeschlossen ist

● Aktuelles Beispiel:

1. Diesmal muss ein ungeordnetes eindimensionales Array sortiert werden: [36,12,96,-1]

2 ] wird als unabhängige geordnete Liste betrachtet, und die verbleibenden Elemente [12, 96, -1] werden als ungeordnete Liste betrachtet

3 Das erste einzufügende Element ist 12. Um 12 in eine einzufügen In der geordneten Liste müssen Sie zunächst 12 und 36 vergleichen. Wenn das eingefügte Element 12 kleiner als 36 ist, müssen Sie 12 vor 36 einfügen, d. h. 36 muss um ein Bit nach hinten verschoben werden.

4. Die Einfügungssortierung erfordert tatsächlich den Vergleich der Gesamtzahl der Array-Elemente abzüglich einer Runde, da das erste Element nicht verglichen werden muss.

$arr = [36,12,96,-1];
//待插入的数
$insertValue = $arr[1];
//待插入数前面的数的索引
$insertIndek = 1 - 1;
//$insertIndek >= 0 保证插入循环时,不越界,保证第一个元素的下标要大于等0
//$insertValue < $arr[$insertIndek] 保证待插入的数还没有找到插入的位置,即待插入的数是小于它前面的那一个元素的
//符合上述条件的,需要将$arr[$insertIndek] 后移
while($insertIndek >= 0 && $insertValue < $arr[$insertIndek]) {
 $arr[$insertIndek+1] = $arr[$insertIndek]; $insertIndek--;
 //代表的就是有序列表的最前面一个元素的前面一个下标 -1;
}
//当退出循环时,代表找到位置 $insertIndek + 1
$arr[$insertIndek + 1] = $insertValue;
//把插入的元素插入到有序列表的第一个位置或者是没发生交换就在本身的位置
$arr = [12,36,96,-1];
//待插入的数
$insertValue = $arr[2];
//待插入数前面的数的索引
$insertIndek = 2 - 1;
//$insertIndek >= 0 保证插入循环时,不越界,保证第一个元素的下标要大于等0
//$insertValue < $arr[$insertIndek] 保证待插入的数还没有找到插入的位置,即待插入的数是小于它前面的那一个元素的
//符合上述条件的,需要将$arr[$insertIndek] 后移
while($insertIndek >= 0 && $insertValue < $arr[$insertIndek]) {
 $arr[$insertIndek+1] = $arr[$insertIndek];
 $insertIndek--;
 //代表的就是有序列表的最前面一个元素的前面一个下标 -1;
}
//当退出循环时,代表找到位置 $insertIndek + 1
$arr[$insertIndek + 1] = $insertValue;//把插入的元素插入到有序列表的第一个位置或者是没发生交换就在本身的位置

und so weiter, um das fertige geordnete Array zu erhalten

5. Der vollständige Code lautet wie folgt:

<?php
class InsertSort
{
 public static function insertArraySort(array $data):array
 { 
 if (!is_array($data)) {
 return [&#39;message&#39; => &#39;待排序的序列非数组&#39;];
 }
 $count = count($data);
 if ($count <= 1) {
 return $data;
 }
 for ($i = 1; $i < $count; $i++) {
 //待插入的元素
 $insertValue = $data[$i];
 //待插入数前面的数的索引
 $insertIndek = $i - 1;
 //$insertIndek >= 0 保证插入循环时,不越界,保证第一个元素的下标要大于等0\
 //$insertValue < $arr[$insertIndek] 保证待插入的数还没有找到插入的位置,即待插入的数是小于它前面的那一个元素的
 //符合上述条件的,需要将$arr[$insertIndek] 后移
 while($insertIndek >= 0 && $insertValue < $data[$insertIndek]) {
 $data[$insertIndek+1] = $data[$insertIndek];
 $insertIndek--;//代表的就是有序列表的最前面一个元素的前面一个下标 -1;
 }
 //当退出循环时,代表找到位置 $insertIndek + 1
 //把插入的元素插入到有序列表的第一个位置
 //或者是没发生交换,即待插入元素大于有序列表的最后一个元素,那么这里只需要将有序列表的最后一个元素的索引 + 1,把待插入元素放在后
 //面一位即可
 $data[$insertIndek + 1] = $insertValue;\ }
 return $data;
 }
 }
$arr = [36,12,96,-1];
var_dump(InsertSort::insertArraySort($arr));

Das obige ist der detaillierte Inhalt vonPHP-Sortieralgorithmus, Einfügungssortierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:learnku.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen