文章详情

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

PHP实现常见排序

时间:2008-05-16  来源:剑心通明




//插入排序(一维数组)

function insert_sort($arr){

    $count = count($arr);

    for($i=1; $i$count; $i++){

        $tmp = $arr[$i];

        $j = $i - 1;

        while($arr[$j] > $tmp){

            $arr[$j+1] = $arr[$j];

            $arr[$j] = $tmp;

            $j--;

        }

    }

    return $arr;

}



//选择排序(一维数组)

function select_sort($arr){

    $count = count($arr);

    for($i=0; $i$count; $i++){

        $k = $i;

        for($j=$i+1; $j$count; $j++){

            if ($arr[$k] > $arr[$j])

                $k = $j;

            if ($k != $i){

                $tmp = $arr[$i];

                $arr[$i] = $arr[$k];

                $arr[$k] = $tmp;

            }

        }

    }

    return $arr;

}


//冒泡排序(一维数组)

function bubble_sort($array){

    $count = count($array);

    if ($count  0) return false;

   

    for($i=0; $i$count; $i++){

        for($j=$count-1; $j>$i; $j--){

            if ($array[$j]  $array[$j-1]){

                $tmp = $array[$j];

                $array[$j] = $array[$j-1];

                $array[$j-1] = $tmp;

            }

        }

    }

    return $array;

}


//快速排序(一维数组)

function quick_sort($array){

    if (count($array)  1) return $array;


    $key = $array[0];

    $left_arr = array();

    $right_arr = array();

    for ($i=1; $icount($array); $i++){

        if ($array[$i]  $key)

            $left_arr[] = $array[$i];

        else

            $right_arr[] = $array[$i];

    }

    $left_arr = quick_sort($left_arr);

    $right_arr = quick_sort($right_arr);

   

    return array_merge($left_arr, array($key), $right_arr);

}



?>


相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载