PHPにおけるクイックソートアルゴリズムの応用例
PHPでは、クイックソートアルゴリズムを使って配列をソートできます。以下に、再帰的に実装したクイックソートアルゴリズムの一例を示します。
function quickSort($array)
{
// 如果数组为空或只有一个元素,则无需排序,直接返回
if (count($array) <= 1) {
return $array;
}
// 选择第一个元素作为基准值
$pivot = $array[0];
$left = $right = [];
// 将比基准值小的元素放在左边,比基准值大的元素放在右边
for ($i = 1; $i < count($array); $i++) {
if ($array[$i] < $pivot) {
$left[] = $array[$i];
} else {
$right[] = $array[$i];
}
}
// 递归对左右两个子数组进行快速排序,并拼接结果
return array_merge(quickSort($left), [$pivot], quickSort($right));
}
// 示例用法
$array = [3, 1, 5, 2, 4];
$result = quickSort($array);
print_r($result);
出力結果は Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 ) で、昇順に配列されていることを示します。
上記の例では、まず配列の最初の要素を基準値として選択し、基準値より小さい要素を左側に、基準値より大きい要素を右側に置きます。その後、再帰的に左右の2つのサブ配列に対してクイックソートを行い、結果を連結します。最後に、完全にソートされた配列を返します。