关闭

PHP实现常见排序

465人阅读 评论(0) 收藏 举报
<?php
//插入排序(一维数组)
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 <= 0return 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<= 1return $array

    
$key = $array[0]; 
    
$left_arr = array(); 
    
$right_arr = array(); 
    
for ($i=1$i<count($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); 


?>
 
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:260443次
    • 积分:3448
    • 等级:
    • 排名:第9636名
    • 原创:80篇
    • 转载:44篇
    • 译文:0篇
    • 评论:26条
    文章分类
    最新评论
    天气预报