如何使用PHP编写堆排序算法
堆排序是一种高效的排序算法,它的核心思想是将待排序的序列构建成一个二叉堆,然后通过不断调整堆的结构来实现排序。本文将介绍如何使用PHP编写堆排序算法,并提供代码示例供参考。
- 堆的定义
在开始编写堆排序算法之前,首先需要明确堆的定义和性质。堆是一个具有以下性质的完全二叉树:对于任意节点i,满足以下两个条件: - 父节点的值总是大于或等于子节点的值(最大堆);
- 父节点的值总是小于或等于子节点的值(最小堆)。
- 调整堆的操作
为了构建一个堆,我们需要了解如何进行堆的调整操作。堆的调整分为两个步骤: - 从最后一个非叶子节点开始,依次将该节点与其子节点进行比较,将较大(或较小)的值交换到父节点的位置;
- 重复上述步骤,直到整个堆的结构满足堆的性质。
下面是一个用PHP实现的堆调整函数示例:
function heapify(&$arr, $n, $i) {
$largest = $i; // 将当前节点标记为最大值节点
$l = 2 * $i + 1; // 左子节点
$r = 2 * $i + 2; // 右子节点
// 如果左子节点大于根节点
if ($l < $n && $arr[$l] > $arr[$largest]) {
$largest = $l;
}
// 如果右子节点大于根节点
if ($r < $n && $arr[$r] > $arr[$largest]) {
$largest = $r;
}
// 如果最大值不等于当前节点,则交换它们的位置
if ($largest != $i) {
$temp = $arr[$i];
$arr[$i] = $arr[$largest];
$arr[$largest] = $temp;
// 递归调整交换之后的子树
heapify($arr, $n, $largest);
}
}
- 堆排序算法
具备了堆的定义和堆的调整操作之后,就可以编写堆排序算法了。堆排序的主要步骤如下: - 构建最大堆:从最后一个非叶子节点开始,依次调用堆调整函数,构建出一个最大堆;
- 排序:将堆顶元素(最大值)与最后一个元素交换位置,然后将堆的大小-1,再调用堆调整函数调整剩余元素的顺序;
- 重复上述步骤,直到堆的大小为1,此时所有元素按照升序排列。
下面是用PHP实现的堆排序函数示例:
function heapSort(&$arr) {
$n = count($arr);
// 构建最大堆
for ($i = ($n / 2) - 1; $i >= 0; $i--) {
heapify($arr, $n, $i);
}
// 排序
for ($i = $n - 1; $i > 0; $i--) {
// 交换堆顶和最后一个元素
$temp = $arr[0];
$arr[0] = $arr[$i];
$arr[$i] = $temp;
// 调整剩余元素的顺序
heapify($arr, $i, 0);
}
}
- 使用堆排序算法
使用堆排序算法非常简单,只需要将待排序的数组作为参数传递给上述的堆排序函数即可。下面是使用堆排序算法对一个数组进行排序的示例:
$arr = [3, 7, 2, 11, 1, 9, 6, 4, 8];
echo "排序前:" . implode(", ", $arr) . "
";
heapSort($arr);
echo "
.........................................................