php排序算法代码说明

1.0参考:十大经典排序算法动画与解析

在这里插入图片描述
$arr = [1, 33, 24, 8, 21, 2, 21, 3, 32, 16, 2, 80];

冒泡排序

for ($i = 0; $i < count($arr) - 1; $i++) {
    // 设定一个标记,若为true,则表示此次循环没有进行交换,也就是待排序列已经有序,排序已经完成。
    $flag = true;
    for ($j = 0; $j < count($arr) - $i - 1; $j++) {
        if ($arr[$j] > $arr[$j + 1]) {
            $temp = $arr[$j];
            $arr[$j] = $arr[$j + 1];
            $arr[$j + 1] = $temp;
            $flag = false;
        }
    }
    if ($flag) break;
}
var_dump($arr);

选择排序

for ($i = 0; $i < count($arr) - 1; $i++) {
    for ($j = $i + 1; $j < count($arr); $j++) {
        if ($arr[$i] > $arr[$j]) {
            $tmp = $arr[$j];
            $arr[$j] = $arr[$i];
            $arr[$i] = $tmp;
        }
    }
}
var_dump($arr);

插入排序

for ($i = 1; $i < count($arr); $i++) {
    $tmp = $arr[$i];
    $j = $i;
    while ($tmp < $arr[$j - 1] && $j > 0) {
        $arr[$j] = $arr[$j - 1];
        $j--;
    }
    if ($j != $i) {
        $arr[$j] = $tmp;
    }
}
var_dump($arr);

希尔排序(即增加了步长的插入排序)

$gap = floor(count($arr) / 2);
while ($gap > 0) {
    for ($i = $gap; $i < count($arr); $i++) {
        $tmp = $arr[$i];
        $j = $i;
        while ($tmp < $arr[$j - $gap] && $j > 0) {
            $arr[$j] = $arr[$j - $gap];
            $j -= $gap;
        }
        if ($j != $i) {
            $arr[$j] = $tmp;
        }
    }
    $gap = floor($gap / 2);
}
var_dump($arr);

归并排序

function arraySlice($arr)
{
    if (count($arr) <= 1) return $arr;
    $mid = floor(count($arr) / 2);
    $left = arraySlice(array_slice($arr, 0, $mid));
    $right = arraySlice(array_slice($arr, $mid));
    return mergeSort($left, $right);
}
function mergeSort($left, $right)
{
    $arr = [];
    while (count($left) && count($right)) {
        $arr[] = $left[0] < $right[0] ? array_shift($left) : array_shift($right);
    }
    return array_merge($arr, $left, $right);
}
$arr = arraySlice($arr);
var_dump($arr);

快速排序

function quickSort($arr)
{
    if (count($arr) <= 1) return $arr;
    $mid = $arr[0];
    $left = $right = [];
    for ($i = 1; $i < count($arr); $i++) {
        if ($arr[$i] < $mid) {
            $left[] = $arr[$i];
        } else {
            $right[] = $arr[$i];
        }
    }
    return array_merge(quickSort($left), [$mid], quickSort($right));
}
$arr = quickSort($arr);
var_dump($arr);

堆排序

//因为是数组,下标从0开始,所以,下标为n根结点的左子结点为2n+1,右子结点为2n+2;
//每次循环拿到最大值放在新长度的数组最后
for($len=count($arr);$len>1;$len--){
  buildHeap($arr,$len);
}
//用数组建立大顶堆
function buildHeap(&$arr,$len){
  //左子结点为2n+1,右子结点为2n+2,所以从($len/2-1)处对一个树进行循环比较即可,然后形成大顶堆
  for($index=intval($len/2)-1; $index>=0; $index--){
    //如果有左子节点,将其下标存进最大值$max
    if($index*2+1<$len){
      $max=$index*2+1;
      //如果有右子结点,比较左右结点的大小,如果右子结点更大,将其结点的下标记录进最大值$max
      if($index*2+2<$len && $arr[$index*2+2]>$arr[$max]){
        $max=$index*2+2;
      }
      //将子结点中较大的和父结点比较,若子结点较大,与父结点交换位置
      if($arr[$max]>$arr[$index]){
        swap($arr,$max,$index);
      }
    }
  }
  //将堆的根(最大的元素)拿出来与最后一个叶子交换,接下来的循环长度-1即可
  swap($arr,0,$len-1);
}
//此函数用来交换数组$arr中下标为$max和$index的数据
function swap(&$arr,$max,$index){
  $tmp=$arr[$max];
  $arr[$max]=$arr[$index];
  $arr[$index]=$tmp;
}
var_dump($arr);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
快速排序是一种常用的排序算法,它的基本思想是通过一趟排序将待排序的数据分割成独立的两部分,其中一部分的所有数据都比另一部分的所有数据小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。 下面是一个使用PHP实现的快速排序算法的示例代码: ```php function quickSort($arr) { // 如果数组长度小于等于1,则直接返回 $length = count($arr); if ($length <= 1) { return $arr; } // 选择一个基准元素 $pivot = $arr[0]; // 初始化左右两个数组 $left = $right = array(); // 遍历数组,将元素分到左右两个数组中 for ($i = 1; $i < $length; $i++) { if ($arr[$i] < $pivot) { $left[] = $arr[$i]; } else { $right[] = $arr[$i]; } } // 递归调用快速排序,并将左右两个数组合并 return array_merge(quickSort($left), array($pivot), quickSort($right)); } // 测试示例 $arr = array(5, 2, 8, 9, 1); $result = quickSort($arr); print_r($result); ``` 这段代码定义了一个名为`quickSort`的函数,它接受一个待排序的数组作为参数,并返回排序后的数组。在函数内部,首先判断数组长度是否小于等于1,如果是,则直接返回原数组。然后选择一个基准元素(这里选择第一个元素),遍历数组,将比基准元素小的元素放入左数组,将比基准元素大的元素放入右数组。最后,递归调用`quickSort`函数对左右两个数组进行排序,并将排序后的左数组、基准元素、排序后的右数组合并返回。 运行上述示例代码,输出结果为:`Array ( => 1 => 2 => 5 => 8 => 9 )`,表示数组已经按照从小到大的顺序排列好了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值