基础排序

2020-12-13 02:24

阅读:318

标签:middle   ++   nbsp   number   insert   php   ret   count   bin   

冒泡排序

function bubble_sort($arr) {

$n=count($arr);
for($i=0;$i$n-1;$i++){
    for($j=$i+1;$j$n;$j++) {
        if($arr[$j]$arr[$i]) {
            $temp=$arr[$i];
            $arr[$i]=$arr[$j];
            $arr[$j]=$temp;
        }
    }
}
return $arr;

}

归并排序

function mergeSort(&$arr, $start, $end)
{
if($start >= $end){
return;
}
$middle = (int)(($start +$end)/2);
mergeSort($arr, $start, $middle);
mergeSort($arr, $middle+1, $end);

merger($arr, $start, $middle, $end);
}

function merger(&$arr, $start, $middle, $end)
{
$i = $start;
$j = $middle+1;
$arrTemp =[];
while($i if($arr[$i] $arrTemp[] =$arr[$i];
$i++;
}else{
$arrTemp[] =$arr[$j];
$j++;
}
}
while($i $arrTemp[] =$arr[$i];
$i++;
}
while($j $arrTemp[] =$arr[$j];
$j++;
}

$i = $start;
foreach ($arrTemp as $key=>$val){
$arr[$i]= $val;
$i++;
}
return ;
}

$arr=array(1,543,64564,89345,98723,77332);
mergeSort($arr, 0,5);

 

 

 

 

 

 

二分查找-递归

function bin_search($arr,$low,$high,$value) {

if($low>$high)
    return false;
else {
    $mid=floor(($low+$high)/2);
    if($value==$arr[$mid])
        return $mid;
    elseif($valuereturn bin_search($arr,$low,$mid-1,$value);
    else
        return bin_search($arr,$mid+1,$high,$value);
}

}

二分查找-非递归

function bin_search($arr,$low,$high,$value) {

while($lowfloor(($low+$high)/2);
    if($value==$arr[$mid])
        return $mid;
    elseif($value-1;
    else
        $low=$mid+1;
}
return false;

}

快速排序

function quick_sort($arr) {

$n=count($arr);
if($n1)
    return $arr;
$key=$arr[0];
$left_arr=array();
$right_arr=array();
for($i=1;$iif($arr[$i]else
        $right_arr[]=$arr[$i];
}
$left_arr=quick_sort($left_arr);
$right_arr=quick_sort($right_arr);
return array_merge($left_arr,array($key),$right_arr);

}

选择排序

function select_sort($arr) {

$n=count($arr);
for($i=0;$i$n;$i++) {
    $k=$i;
    for($j=$i+1;$j$n;$j++) {
       if($arr[$j]$arr[$k])
           $k=$j;
    }
    if($k!=$i) {
        $temp=$arr[$i];
        $arr[$i]=$arr[$k];
        $arr[$k]=$temp;
    }
}
return $arr;

}

插入排序

function insertSort($arr) {

$n=count($arr);
for($i=1;$i$n;$i++) {
    $tmp=$arr[$i];
    $j=$i-1;
    while($arr[$j]>$tmp) {
        $arr[$j+1]=$arr[$j];
        $arr[$j]=$tmp;
        $j--;
        if($jbreak;
    }
}
return $arr;

}

基础排序

标签:middle   ++   nbsp   number   insert   php   ret   count   bin   

原文地址:https://www.cnblogs.com/wxc1/p/11037475.html


评论


亲,登录后才可以留言!