文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>PHP实现各种排序算法

PHP实现各种排序算法

时间:2007-06-09  来源:windlike


                ?php
// 功能: PHP实现各种排序算法
// Author: windlike
// Datetime: 2007-06-09
// 冒泡排序
function BubbleSort($arr){
    $num = count($arr);
    for($i=1;$i$num;$i++){
        for($j=$num-1;$j>=$i;$j--){
            if($arr[$j]$arr[$j-1]){
                $iTemp = $arr[$j-1];
                $arr[$j-1] = $arr[$j];
                $arr[$j] = $iTemp;
            }
        }
    }
    return $arr;
}
// 交换法排序
function ExchangeSort($arr){
    $num = count($arr);
    for($i=0;$i$num-1;$i++){
        for($j=$i+1;$j$num;$j++){
            if($arr[$j]$arr[$i]){
                $iTemp = $arr[$i];
                $arr[$i] = $arr[$j];
                $arr[$j] = $iTemp;
            }
        }
    }
    return $arr;
}
// 选择法排序
function SelectSort($arr){
    $num = count($arr);
    for($i=0;$i$num-1;$i++){
        $iTemp = $arr[$i];
        $iPos = $i;
        for($j=$i+1;$j$num;$j++){
            if($arr[$j]$iTemp){
                $iTemp = $arr[$j];
                $iPos = $j;
            }
        }
        $arr[$iPos] = $arr[$i];
        $arr[$i] = $iTemp;
    }
    return $arr;
}
// 插入法排序
function InsertSort($arr){
    $num = count($arr);
    for($i=1;$i$num;$i++){
        $iTemp = $arr[$i];
        $iPos = $i-1;
        while(($iPos>=0) && ($iTemp$arr[$iPos])){
            $arr[$iPos+1] = $arr[$iPos];
            $iPos--;
        }
        $arr[$iPos+1] = $iTemp;
    }
    return $arr;
}
// 快速排序
function QuickSort($arr){
    $num = count($arr);
    $l=$r=0;
    for($i=1;$i$num;$i++){
        if($arr[$i]  $arr[0]){
            $left[] = $arr[$i];
            $l++;
        }else{
            $right[] = $arr[$i];
            $r++;
        }        
    }
    if($l > 1){
        $left = QuickSort($left);
    }
    $new_arr = $left;
    $new_arr[] = $arr[0];
    if($r > 1){
        $right = QuickSort($right);
    }
    for($i=0;$i$r;$i++){
        $new_arr[] = $right[$i];
    }
    return $new_arr;
}
$arr = array(7,1,6,5,2);
$arr_new = QuickSort($arr);
echo "";
print_r($arr_new);
echo "";
?>
               
               

相关阅读 更多 +
排行榜 更多 +
jojo的奇妙冒险手机版下载

jojo的奇妙冒险手机版下载

飞行射击 下载
雪糕工厂 v9.87.13.02 安卓版

雪糕工厂 v9.87.13.02 安卓版

休闲益智 下载
雪糕工厂 v9.87.13.02 安卓版

雪糕工厂 v9.87.13.02 安卓版

休闲益智 下载