|
極有可能今后我也會(huì)遇到的。
問題:php不用內(nèi)置函數(shù)對(duì)數(shù)組排序,可能是降序或者升序
第一種方法:傳說中的冒泡法
復(fù)制代碼 代碼如下:
function arraysort($data, $order = 'asc') {
//asc升序 desc降序
$temp = array ();
$count = count ( $data );
if ($count <= 0)
return false; //傳入的數(shù)據(jù)不正確
if ($order == 'asc') {
for($i = 0; $i < $count; $i ++) {
for($j = $count - 1; $j > $i; $j --) {
if ($data [$j] < $data [$j - 1]) {
//交換兩個(gè)數(shù)據(jù)的位置
$temp = $data [$j];
$data [$j] = $data [$j - 1];
$data [$j - 1] = $temp;
}
}
}
} else {
for($i = 0; $i < $count; $i ++) {
for($j = $count - 1; $j > $i; $j --) {
if ($data [$j] > $data [$j - 1]) {
$temp = $data [$j];
$data [$j] = $data [$j - 1];
$data [$j - 1] = $temp;
}
}
}
}
return $data;
}
$data = array (7, 5, 3, 8, 9, 1, 5, 3, 1, 24, 3, 87, 0, 33, 1, 12, 34, 54, 66, 32 );
var_dump ( arraysort ( $data ) ); //升序
echo ('<br>');
var_dump ( arraysort ( $data ,'desc') );//降序
第二種方法:不知道取個(gè)什么名字好,就叫插入法吧! 主站蜘蛛池模板: 永安市| 商水县| 汉寿县| 临海市| 两当县| 敦煌市| 凌云县| 常山县| 洛南县| 开平市| 伊金霍洛旗| 连云港市| 红河县| 元江| 绥棱县| 平定县| 本溪| 定边县| 花莲市| 八宿县| 基隆市| 荆门市| 安福县| 二连浩特市| 龙井市| 克东县| 壤塘县| 即墨市| 香港| 增城市| 兴隆县| 南乐县| 资阳市| 南郑县| 土默特左旗| 威远县| 那曲县| 太原市| 枣阳市| 达拉特旗| 湄潭县|