php一维二维数组键排序方法实例总结
本文实例总结了php一维二维数组键排序方法。分享给大家供大家参考。具体方法如下:
在php中数组排序一直是一个老生常谈的问题,下面我们来集中讲一下关于在php中一维数组与二维数组排序的实现程序,相信对大家有一定的参考借鉴价值.
功能:对数组进行重新排序.
说明:冒泡排序(一维数组)(二维数组某个健排序)
两两比较待排序数据元素的大小,发现两个数据元素的次序相反时即进行交换,直到没有反序的数据元素为止
设想被排序的数组R[1..N]垂直竖立,将每个数据元素看作有重量的气泡,从下往上扫描数组,凡扫描违反原则的轻气泡,就使其向上”漂浮”.如此反复进行.直到最后任何两个气都是轻者在上,重者在下为止.
/** *冒泡排序(一维数组)(二维数组某个健排序) *两两比较待排序数据元素的大小,发现两个数据元素的次序相反时即进行交换,直到没有反序的数据元素为止 *设想被排序的数组R[1..N]垂直竖立,将每个数据元素看作有重量的气泡,从下往上扫描数组,凡扫描违反原则的轻气泡,就使其向上"漂浮".如此反复进行. *直到最后任何两个气都是轻者在上,重者在下为止. */ functionbubble_sort($array,$key=null){ $count=count($array); if($count<0){ returnfalse; } for($i=0;$i<$count;$i++){ for($j=$count-1;$j>$i;$j--){ if($key&&isset($array[$key])){//二维数组健存在 if($array[$j][$key]<$array[$j-1][$key]){ $tmp=$array[$j]; $array[$j]=$array[$j-1]; $array[$j-1]=$tmp; } }else{//一维数组 if($array[$j]<$array[$j-1]){ $tmp=$array[$j]; $array[$j]=$array[$j-1]; $array[$j-1]=$tmp; } } } } return$array; }
array_multisort排序使用方法
array_multisort()对二位数组按照指定键值排序的使用方法
本例中定义了一个名为$data的二维数组,然后对它进行排序,方法如下
$data[]=array('volume'=>67,'edition'=>2); $data[]=array('volume'=>86,'edition'=>1); $data[]=array('volume'=>85,'edition'=>6); $data[]=array('volume'=>98,'edition'=>2); $data[]=array('volume'=>86,'edition'=>6); $data[]=array('volume'=>67,'edition'=>7); //取得列的列表 foreach($dataas$key=>$row){ $volume[$key] =$row['volume']; $edition[$key]=$row['edition']; } //将数据根据volume降序排列,根据edition升序排列 //把$data作为最后一个参数,以通用键排序 array_multisort($volume,SORT_DESC,$edition,SORT_ASC,$data); print_r($data);
执行后打印结果如下:
Array ( [0]=>Array ( [volume]=>98 [edition]=>2 ) [1]=>Array ( [volume]=>86 [edition]=>1 ) [2]=>Array ( [volume]=>86 [edition]=>6 [3]=>Array ( [volume]=>85 [edition]=>6 ) [4]=>Array ( [volume]=>67 [edition]=>2 ) [5]=>Array ( [volume]=>67 [edition]=>7 ) )
一维数组排序我们只要使用sort()就可以了,相对应的asort($arr);函数,是按键值排序,且维持原有的键值关系。
同样原理,rsort();arsort();krsort();函数除了排序是按降序排列外,其它与sort();rsort();ksort();相同。
希望本文所述对大家的PHP程序设计有所帮助。