麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 邏輯算法 > 正文

PHP 排序算法之插入排序

2020-03-22 16:21:53
字體:
來源:轉載
供稿:網友
插入排序 Insert Sort

● 插入排序的思想:

將一個待排序的無序的數組看作是兩個列表,一個有序的列表,一個無序的列表,從無序的列表每次拿出一個待插入的元素,插入到有序的列表中,直到html' target='_blank'>無序列表為空,排序完畢

● 實際舉例:

1. 有一個無序的一維數組是這次需要排序的數組,數組是:[36,12,96,-1]

2. 首先把數組的第一個元素 [36] 看作是一個獨立的有序的列表,把剩下的元素 [12, 96, -1] 看作是一個無序的列表

3. 第一個待插入的元素就是 12,要把 12 插入到有序的列表中,首先需要 12 和 36 比較,如果帶插入的元素 12 小于 36, 就需要把 12 插入到 36前面,也就是 36 要后移一位。

4. 插入排序實際是需要比較數組元素的總數減一輪,因為第一個元素不需要比較。

$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;//把插入的元素插入到有序列表的第一個位置或者是沒發生交換就在本身的位置

依次類推,得到完成的有序數組

5. 完整代碼如下:

<?phpclass InsertSort{ public static function insertArraySort(array $data):array {  if (!is_array($data)) { return ['message' => '待排序的序列非數組']; } $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));

以上就是PHP 排序算法之插入排序的詳細內容,更多請關注 其它相關文章!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 婷婷中文字幕一区二区三区 | 99精品视频在线看 | 久草在线播放视频 | chinese xxxx hd pron8 tube | 成人偷拍片视频在线观看 | 在线观看一二三 | 久久精品小短片 | www.99久久久| 国产色视频在线观看免费 | 成人一级视频在线观看 | 久久人人爽人人爽人人片av高请 | 99精品国产成人一区二区 | 精品国产乱码一区二区三区四区 | 国产精品久久国产精麻豆96堂 | 国产婷婷一区二区三区 | 成年人激情在线 | 四虎久草 | 性猛aa久久久 | 国产精品午夜一区 | 19禁国产精品福利视频 | 免费观看的毛片手机视频 | 免费看黄色三级毛片 | 国产女同玩人妖 | 爱操成人网 | 久久久久久久久久久影视 | 国产精品亚洲一区二区三区在线观看 | 97伦理| 美国av免费看 | 国产第一页精品 | 国产午夜精品久久久 | 成码无人av片在线观看网站 | 欧美日韩手机在线观看 | 免费黄色入口 | 成人三级视频在线观看 | 中国女警察一级毛片视频 | 午夜精品影院 | 免费观看黄色影片 | 午夜久久电影 | 一色屋任你操 | 色婷婷久久久亚洲一区二区三区 | 精品一区二区免费视频视频 |