亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

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

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 排序算法之插入排序的詳細內容,更多請關注 其它相關文章!

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美午夜影院在线视频| 91精品视频免费观看| 日韩欧美亚洲成人| 97在线看免费观看视频在线观看| 国产噜噜噜噜久久久久久久久| 欧美精品第一页在线播放| 超在线视频97| 亚洲精品中文字| 久久艳片www.17c.com| 97精品伊人久久久大香线蕉| 国产福利视频一区二区| 精品久久久久久久大神国产| 51视频国产精品一区二区| 亚洲精品天天看| 亚洲a成v人在线观看| 久久久免费观看视频| 国外日韩电影在线观看| 91在线免费网站| 国产成人精品久久亚洲高清不卡| 国产91精品视频在线观看| 久久精品视频亚洲| 亚洲精品视频免费在线观看| 九九热最新视频//这里只有精品| 欧美第一淫aaasss性| 国产精品高精视频免费| 日本亚洲欧美成人| 91免费精品国偷自产在线| 欧美韩日一区二区| 日韩中文字幕免费| 欧美激情在线有限公司| 亚洲性日韩精品一区二区| 亚洲www视频| 国内精品久久久久久| 日韩在线播放av| 久久成人18免费网站| 欧美老女人性生活| 国产精品偷伦视频免费观看国产| 久久久久亚洲精品成人网小说| 国产精品三级久久久久久电影| 亚洲第一区第一页| 欧美亚洲成人免费| 在线观看欧美成人| 国产精品自拍偷拍视频| 国产精品久久久久久亚洲调教| 国产91ⅴ在线精品免费观看| 国模私拍一区二区三区| 精品国产欧美成人夜夜嗨| 羞羞色国产精品| 色妞色视频一区二区三区四区| 午夜美女久久久久爽久久| 成人午夜激情免费视频| 亚洲精品天天看| 久久这里有精品| 亚洲精品自拍偷拍| 日韩资源在线观看| 亚洲激情自拍图| 亚洲最新av在线网站| 国产欧美欧洲在线观看| 成人国产精品久久久| 欧美亚州一区二区三区| 性色av一区二区咪爱| 亚洲综合日韩中文字幕v在线| 亚洲人成电影在线播放| 精品亚洲国产成av人片传媒| 黄色精品一区二区| 欧美夜福利tv在线| 欧美亚洲视频在线看网址| 成人在线精品视频| 精品亚洲aⅴ在线观看| 菠萝蜜影院一区二区免费| 国产日韩欧美日韩大片| 日韩欧美国产高清91| 91在线免费视频| 日韩高清av一区二区三区| 欧美性xxxxhd| 精品国模在线视频| 一本色道久久综合狠狠躁篇的优点| 国产精品视频最多的网站| 精品久久久久久久久国产字幕| 国产专区精品视频| 成人精品久久一区二区三区| 国产精品露脸自拍| 日韩欧美在线免费| 亚洲片av在线| 一色桃子一区二区| 成人免费在线视频网站| 一本色道久久综合亚洲精品小说| 国产人妖伪娘一区91| 亚洲人成77777在线观看网| 欧美性理论片在线观看片免费| 97香蕉久久夜色精品国产| 国产亚洲免费的视频看| 亚洲精品中文字| 亚洲精品网址在线观看| 美日韩丰满少妇在线观看| 国产精品99蜜臀久久不卡二区| 欧美成人一区在线| 欧美午夜女人视频在线| 97超碰蝌蚪网人人做人人爽| 日韩欧美a级成人黄色| 91精品视频网站| 亚洲国产欧美久久| 亚洲高清不卡av| 国产精品欧美日韩| 97香蕉超级碰碰久久免费软件| 精品国产区一区二区三区在线观看| 欧美精品激情blacked18| 久久精品成人一区二区三区| 最近2019中文字幕一页二页| 欧美日韩综合视频网址| 69久久夜色精品国产7777| 日本久久久久久久久| 精品美女永久免费视频| 欧美日韩成人在线观看| 成人高清视频观看www| 亚洲影院色无极综合| 亚洲色图综合网| 日韩美女视频免费在线观看| 国产一区二区三区在线观看网站| 日本高清视频一区| 久久精品91久久久久久再现| 欧美理论在线观看| 国产精品成人播放| 亚洲人成电影网站色…| 久久精品视频中文字幕| 高清一区二区三区日本久| 91中文精品字幕在线视频| 日韩欧美高清视频| 国产日韩av高清| 欧美精品一区在线播放| 欧美日韩精品在线视频| 亚洲视频专区在线| 全亚洲最色的网站在线观看| 这里只有精品丝袜| 51色欧美片视频在线观看| 操日韩av在线电影| 日韩av黄色在线观看| 7777免费精品视频| 亚洲国产精品久久精品怡红院| 91在线视频精品| 欧美中文在线字幕| 国产精品v日韩精品| 国产男女猛烈无遮挡91| 欧美色欧美亚洲高清在线视频| 欧美电影免费观看| 97精品视频在线观看| 日韩av在线免费观看一区| 国产精品男人爽免费视频1| 亚洲成人在线网| 久久全球大尺度高清视频| 亚洲欧洲午夜一线一品| 亚洲人成在线一二| 国产精品99久久久久久白浆小说| 国产日韩av在线播放| 亚洲女人天堂av| 亚洲www在线| 少妇av一区二区三区| 欧美日韩国产va另类| 在线成人免费网站| 亚洲网站视频福利| 精品爽片免费看久久| 久久色免费在线视频| 国产成人黄色av| 日韩美女在线观看|