例: 復制代碼 代碼如下: $arr = array(3,5,-1,0,2); for($i=0;$i<count($arr)-1;$i++){ for($j=0;$j<count($arr)-1-$i;$j++){ if($arr[$j]>$arr[$j+1]){ $t " /> 午夜DY888国产精品影院,亚洲中文字幕一二三四区苍井空 ,黄色片网站下载

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

PHP中數組的三種排序方法分享

一、冒泡排序法
說明:找到最大的數,排列到最后面,然后繼續找

例:
復制代碼 代碼如下:
$arr = array(3,5,-1,0,2);
for($i=0;$i<count($arr)-1;$i++){
for($j=0;$j<count($arr)-1-$i;$j++){
if($arr[$j]>$arr[$j+1]){
$temp = $arr[$j];
$arr[$j]=$arr[$j+1];
$arr[$j+1]=$temp;
}
}
}

理解:
3,5,-1,0,2
//從第一個數開始往后比較,如果比后面的數大則與后面的數調位置
//第一次,3小于5,那么不變
//第二次,5大于-1,那么變成
3,-1,5,0,2
//第三次,5大于0
3,-1,0,5,2
//第四次,5大于2
3,-1,0,2,5
至此完成一次內循環,此時最后一個數完成排序,下次將不參與
3,-1,0,2,5第二次外循環開始 第一次:3大于-1
-1,3,0,2,5
第二次:3大于0
-1,0,3,2,5
第三次:3大于2
-1,0,2,3,5
至此完成后面兩位數的排序了,接下來類推
-1,0,2,3,5
二、選擇排序法
說明:先假設第一個數就是最小的數,然后將后面的數依次與它比較,如果假設的數不是最小的數,就將它與后面的最小的數調換位置
復制代碼 代碼如下:
$arr=array(2,1,-1,3,0);
for($i=0;$i<count($arr)-1;$i++){
$minval = $arr[$i];
$minindex = $i;
for($j=1+$i;$j<count($arr);$j++){
if($arr[$j]<$minval){
$minval = $arr[$j];
$minindex = $j;
}
}
$temp = $arr[$i];
$arr[$i] = $arr[$minindex];
$arr[$minindex] = $temp;
}

理解:
2,1,-1,3,0
//先假設第一個數2為最小值,它后面的數依次與2做比較,尋找到最小的那個數
過程:
1小于2,那么minval=1
-1小于1,那么minval=-1
3大于-1,不變
0大于-1,不變
那么現在就找到了該數組中最小的數了為-1
將-1與2調換位置就完成第一個數的排序了
那么現在數組變成
-1,1,2,3,0
現在第一個數-1已經為有序,所以不參與比較了,往后面繼續
現在假設minval=1
2大于1,不變
3大于1,不變
0小于1,那么minval=0
現在一次循環完成,調換0與1的位置完成第二個數的排序
那么現在數組變成
-1,0,2,3,1
//后面的推法與上面相同。。。

三、插入排序法

說明:先假設一個數組中的第一個數為單獨的有序數組,再將后面的一個數與它【這里隨它I的增長,就變成它們了】做比較,如果后面的數比假設的數還小,則將小的那個數后移,最后將那個數移到最前面
復制代碼 代碼如下:
$arr=array(2,1,-1,3,0);
for($i=1;$i<count($arr);$i++){
$insertval=$arr[$i];
$insertindex = $i-1;
while($insertindex>=0 && $insertval<$arr[$insertindex]){
$arr[$insertindex+1]=$arr[$insertindex];
$insertindex--;
}
$temp = $arr[$i];
$arr[$insertindex+1]=$insertval;
}

理解:
2,1,-1,3,0
//第一次,先保存待插入的數1為insertval,再拿 insertval 與2比較,1小于2,所以把2后移,變成如下的圖
2,2,-1,3,0
//此時2前面沒有數字了,insertindex=0,所以比較完成,那么將insertval插入到尋找到的這個位置。變成如下圖
1,2,-1,3,0
//此時,1,2變成有序數組
//第二次,先保存待插入的數-1為insertval,再拿insertval與2做比較,-1小于2,所以把2后移,變成如下圖
1,2,2,3,0
//此時,再拿insertval與1做比較,-1小于1,那么把-1后移,變成如下圖(這就是一個拿待插入數與前面的有序數組比較的過程)
1,1,2,3,0
//此時,insertindex到頭了,所以將insertval插入該位置
-1,1,2,3,0
//后面推法如上

php技術PHP中數組的三種排序方法分享,轉載需保留來源!

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

主站蜘蛛池模板: 嫩草影院在线观看精品视频 | 亚洲国产日韩制服在线观看 | 夜夜狂射影院欧美极品 | 亚洲免费成人 | 日韩成人性视频 | 18禁止观看免费私人影院 | 国产精品久久自在自2021 | 十八禁啪啦啪漫画 | 国产精品人妻无码久久久奥特曼 | 妻子+免费观看完整 | 久操久操久操 | 国产在线视精品在亚洲 | 强开少妇嫩苞又嫩又紧九色 | 国内精品欧美久久精品 | 国产亚洲精品字幕在线观看 | 神马影院午夜伦理限级 | 国产亚洲AV精品无码麻豆 | 青青青青草原国产免费 | 国模孕妇模特季玥之粉红 | 国产精品igao视频网网址 | 青青国产在线观看视频 | 牢记永久免费网址 | 精品一区二区三区色花堂 | 最近中文字幕无吗免费高清 | old老男人野外树林tv | 成人在线免费视频播放 | 欧美自拍亚洲综合图区 | 国产精品成人影院 | 伦理片在线线看手机版 | 国产精品久AAAAA片 | 欧美日韩中文在线字幕视频 | 好吊日视频在线 | 亚洲裸舞 hd | 久久精品熟一区二区三区 | 嫩交18xxxx| 一本道久久综合久久88 | 花蝴蝶在线观看中字 | 闺蜜扒开我尿口使劲揉 | 欧美顶级情欲片免费看 | 调教美丽的白丝袜麻麻视频 | 欧美精品AV精品一区视频 |