基础排序

Posted wxc1

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基础排序相关的知识,希望对你有一定的参考价值。

冒泡排序

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<=$middle && $j<=$end)
if($arr[$i] <= $arr[$j])
$arrTemp[] =$arr[$i];
$i++;
else
$arrTemp[] =$arr[$j];
$j++;


while($i <= $middle)
$arrTemp[] =$arr[$i];
$i++;

while($j<=$end)
$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($value<$arr[$mid])
        return bin_search($arr,$low,$mid-1,$value);
    else
        return bin_search($arr,$mid+1,$high,$value);

二分查找-非递归

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

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

return false;

快速排序

function quick_sort($arr)

$n=count($arr);
if($n<=1)
    return $arr;
$key=$arr[0];
$left_arr=array();
$right_arr=array();
for($i=1;$i<$n;$i++) 
    if($arr[$i]<=$key)
        $left_arr[]=$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($j<0)
            break;
    

return $arr;

以上是关于基础排序的主要内容,如果未能解决你的问题,请参考以下文章

初识Spring源码 -- doResolveDependency | findAutowireCandidates | @Order@Priority调用排序 | @Autowired注入(代码片段

算法排序之堆排序

[vscode]--HTML代码片段(基础版,reactvuejquery)

[Go] 通过 17 个简短代码片段,切底弄懂 channel 基础

以下代码片段的时间复杂度是多少?

markdown 数组排序片段