PHP 数组自定义排序算法的编写指南

2024年 4月 27日 18.1k 0

如何编写自定义 php 数组排序算法?冒泡排序:通过比较和交换相邻元素来排序数组。选择排序:每次选择最小或最大元素并将其与当前位置交换。插入排序:逐个插入元素到有序部分。

PHP 数组自定义排序算法的编写指南

PHP 数组自定义排序算法的编写指南

简介
数组排序是编程中一项常见任务,它允许我们根据特定标准重新组织数组中的元素。PHP 提供了多种内建排序算法,但有时我们需要根据自定义逻辑对数组进行排序,这就需要我们编写自己的自定义排序算法。

冒泡排序
冒泡排序是一种简单的排序算法,它通过反复比较相邻元素并交换它们的位置来对数组进行排序。

function bubbleSort(array &$arr) {
    $n = count($arr);
    for ($i = 0; $i < $n - 1; $i++) {
        for ($j = 0; $j  $arr[$j + 1]) {
                $tmp = $arr[$j];
                $arr[$j] = $arr[$j + 1];
                $arr[$j + 1] = $tmp;
            }
        }
    }
}

选择排序
选择排序是一种基于选择最小或最大元素并将其与当前位置交换的排序算法。

function selectionSort(array &$arr) {
    $n = count($arr);
    for ($i = 0; $i < $n - 1; $i++) {
        $min_idx = $i;
        for ($j = $i + 1; $j < $n; $j++) {
            if ($arr[$j] < $arr[$min_idx]) {
                $min_idx = $j;
            }
        }

        $tmp = $arr[$i];
        $arr[$i] = $arr[$min_idx];
        $arr[$min_idx] = $tmp;
    }
}

插入排序
插入排序是一种基于逐个插入元素到有序部分的排序算法。

function insertionSort(array &$arr) {
    $n = count($arr);
    for ($i = 1; $i = 0 && $arr[$j] > $key) {
            $arr[$j + 1] = $arr[$j];
            $j--;
        }

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

实战案例
让我们使用冒泡排序算法按升序对以下 PHP 数组进行排序:

$arr = [5, 2, 8, 3, 1];

调用冒泡排序函数:

bubbleSort($arr);

排序后的数组:

[1, 2, 3, 5, 8]

以上就是PHP 数组自定义排序算法的编写指南的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论