PHP中數(shù)組的三種排序方法分享
更新時間:2012年05月07日 21:42:28 作者:
PHP中數(shù)組的三種排序方法,主要包括冒泡排序法、選擇排序法、插入排序法,需要的朋友可以參考下
一、冒泡排序法
說明:找到最大的數(shù),排列到最后面,然后繼續(xù)找
例:
$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
//從第一個數(shù)開始往后比較,如果比后面的數(shù)大則與后面的數(shù)調位置
//第一次,3小于5,那么不變
//第二次,5大于-1,那么變成
3,-1,5,0,2
//第三次,5大于0
3,-1,0,5,2
//第四次,5大于2
3,-1,0,2,5
至此完成一次內循環(huán),此時最后一個數(shù)完成排序,下次將不參與
3,-1,0,2,5第二次外循環(huán)開始 第一次:3大于-1
-1,3,0,2,5
第二次:3大于0
-1,0,3,2,5
第三次:3大于2
-1,0,2,3,5
至此完成后面兩位數(shù)的排序了,接下來類推
-1,0,2,3,5
二、選擇排序法
說明:先假設第一個數(shù)就是最小的數(shù),然后將后面的數(shù)依次與它比較,如果假設的數(shù)不是最小的數(shù),就將它與后面的最小的數(shù)調換位置
$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
//先假設第一個數(shù)2為最小值,它后面的數(shù)依次與2做比較,尋找到最小的那個數(shù)
過程:
1小于2,那么minval=1
-1小于1,那么minval=-1
3大于-1,不變
0大于-1,不變
那么現(xiàn)在就找到了該數(shù)組中最小的數(shù)了為-1
將-1與2調換位置就完成第一個數(shù)的排序了
那么現(xiàn)在數(shù)組變成
-1,1,2,3,0
現(xiàn)在第一個數(shù)-1已經(jīng)為有序,所以不參與比較了,往后面繼續(xù)
現(xiàn)在假設minval=1
2大于1,不變
3大于1,不變
0小于1,那么minval=0
現(xiàn)在一次循環(huán)完成,調換0與1的位置完成第二個數(shù)的排序
那么現(xiàn)在數(shù)組變成
-1,0,2,3,1
//后面的推法與上面相同。。。
三、插入排序法
說明:先假設一個數(shù)組中的第一個數(shù)為單獨的有序數(shù)組,再將后面的一個數(shù)與它【這里隨它I的增長,就變成它們了】做比較,如果后面的數(shù)比假設的數(shù)還小,則將小的那個數(shù)后移,最后將那個數(shù)移到最前面
$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
//第一次,先保存待插入的數(shù)1為insertval,再拿 insertval 與2比較,1小于2,所以把2后移,變成如下的圖
2,2,-1,3,0
//此時2前面沒有數(shù)字了,insertindex=0,所以比較完成,那么將insertval插入到尋找到的這個位置。變成如下圖
1,2,-1,3,0
//此時,1,2變成有序數(shù)組
//第二次,先保存待插入的數(shù)-1為insertval,再拿insertval與2做比較,-1小于2,所以把2后移,變成如下圖
1,2,2,3,0
//此時,再拿insertval與1做比較,-1小于1,那么把-1后移,變成如下圖(這就是一個拿待插入數(shù)與前面的有序數(shù)組比較的過程)
1,1,2,3,0
//此時,insertindex到頭了,所以將insertval插入該位置
-1,1,2,3,0
//后面推法如上
說明:找到最大的數(shù),排列到最后面,然后繼續(xù)找
例:
復制代碼 代碼如下:
$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
//從第一個數(shù)開始往后比較,如果比后面的數(shù)大則與后面的數(shù)調位置
//第一次,3小于5,那么不變
//第二次,5大于-1,那么變成
3,-1,5,0,2
//第三次,5大于0
3,-1,0,5,2
//第四次,5大于2
3,-1,0,2,5
至此完成一次內循環(huán),此時最后一個數(shù)完成排序,下次將不參與
3,-1,0,2,5第二次外循環(huán)開始 第一次:3大于-1
-1,3,0,2,5
第二次:3大于0
-1,0,3,2,5
第三次:3大于2
-1,0,2,3,5
至此完成后面兩位數(shù)的排序了,接下來類推
-1,0,2,3,5
二、選擇排序法
說明:先假設第一個數(shù)就是最小的數(shù),然后將后面的數(shù)依次與它比較,如果假設的數(shù)不是最小的數(shù),就將它與后面的最小的數(shù)調換位置
復制代碼 代碼如下:
$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
//先假設第一個數(shù)2為最小值,它后面的數(shù)依次與2做比較,尋找到最小的那個數(shù)
過程:
1小于2,那么minval=1
-1小于1,那么minval=-1
3大于-1,不變
0大于-1,不變
那么現(xiàn)在就找到了該數(shù)組中最小的數(shù)了為-1
將-1與2調換位置就完成第一個數(shù)的排序了
那么現(xiàn)在數(shù)組變成
-1,1,2,3,0
現(xiàn)在第一個數(shù)-1已經(jīng)為有序,所以不參與比較了,往后面繼續(xù)
現(xiàn)在假設minval=1
2大于1,不變
3大于1,不變
0小于1,那么minval=0
現(xiàn)在一次循環(huán)完成,調換0與1的位置完成第二個數(shù)的排序
那么現(xiàn)在數(shù)組變成
-1,0,2,3,1
//后面的推法與上面相同。。。
三、插入排序法
說明:先假設一個數(shù)組中的第一個數(shù)為單獨的有序數(shù)組,再將后面的一個數(shù)與它【這里隨它I的增長,就變成它們了】做比較,如果后面的數(shù)比假設的數(shù)還小,則將小的那個數(shù)后移,最后將那個數(shù)移到最前面
復制代碼 代碼如下:
$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
//第一次,先保存待插入的數(shù)1為insertval,再拿 insertval 與2比較,1小于2,所以把2后移,變成如下的圖
2,2,-1,3,0
//此時2前面沒有數(shù)字了,insertindex=0,所以比較完成,那么將insertval插入到尋找到的這個位置。變成如下圖
1,2,-1,3,0
//此時,1,2變成有序數(shù)組
//第二次,先保存待插入的數(shù)-1為insertval,再拿insertval與2做比較,-1小于2,所以把2后移,變成如下圖
1,2,2,3,0
//此時,再拿insertval與1做比較,-1小于1,那么把-1后移,變成如下圖(這就是一個拿待插入數(shù)與前面的有序數(shù)組比較的過程)
1,1,2,3,0
//此時,insertindex到頭了,所以將insertval插入該位置
-1,1,2,3,0
//后面推法如上
您可能感興趣的文章:
- PHP二維數(shù)組排序的3種方法和自定義函數(shù)分享
- php對數(shù)組排序代碼分享
- 一個PHP二維數(shù)組排序的函數(shù)分享
- php二維數(shù)組排序方法(array_multisort usort)
- php對數(shù)組排序的簡單實例
- php對二維數(shù)組進行排序的簡單實例
- php對二維數(shù)組按指定鍵值key排序示例代碼
- php二維數(shù)組排序詳解
- PHP數(shù)組排序函數(shù)合集 以及它們之間的聯(lián)系分析
- PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
- 解析PHP中數(shù)組元素升序、降序以及重新排序的函數(shù)
- php二維數(shù)組排序與默認自然排序的方法介紹
- php比較多維數(shù)組中值的大小排序實現(xiàn)代碼
- php中的一些數(shù)組排序方法分享
- php 數(shù)組動態(tài)添加實現(xiàn)代碼(最土團購系統(tǒng)的價格排序)
- PHP 多維數(shù)組的排序問題 根據(jù)二維數(shù)組中某個項排序
- php數(shù)組函數(shù)序列之krsort()- 對數(shù)組的元素鍵名進行降序排序,保持索引關系
- 不使用php api函數(shù)實現(xiàn)數(shù)組的交換排序示例
相關文章
關于shopex同步ucenter的redirect問題,導致script不運行
本文小編為大家介紹,關于shopex同步ucenter的redirect問題,導致script不運行。有需要的朋友可以參考一下2013-04-04php使用gettimeofday函數(shù)返回當前時間并存放在關聯(lián)數(shù)組里
這篇文章主要介紹了php使用gettimeofday函數(shù)返回當前時間并存放在關聯(lián)數(shù)組里的方法,涉及php中gettimeofday函數(shù)的使用技巧,需要的朋友可以參考下2015-03-03php中的四舍五入函數(shù)代碼(floor函數(shù)、ceil函數(shù)、round與intval)
php 中處理浮點數(shù)時經(jīng)常要需要四舍五入。在php 中有兩個函數(shù)適用于這種情況:floor函數(shù)、ceil函數(shù)和round函數(shù)2014-07-07