冒泡,快排,二分查詢,都是面試常問的幾個演算法題目,雖然簡單,但是一段時間不用的話就很容易忘記,這裡我用PHP實現了一下,溫故而知新。
排序
氣泡排序
每一次冒出一個最大的值
function bubbleSort($arr)
{
$count = count($arr);
if ($count == 0) return false;
for ($i = 0; $i < $count - 1; $i++) {
for ($k = 0; $k < $count - 1 - $i; $k++) {
if ($arr[$k] < $arr[$k + 1]) {
$tmp = $arr[$k];
$arr[$k] = $arr[$k + 1];
$arr[$k + 1] = $tmp;
}
}
}
return $arr;
}
快速排序
選擇一個值作為基準,比他小的放在左邊,比他大的放在右邊,然後對左右遞迴,最後合併
function quickSort($arr)
{
$count = count($arr);
if ($count <= 1) return $arr;
$base = $arr[0];
$left = $right = [];
for ($i = 1; $i < $count; $i++) {
if ($arr[$i] < $base) {
$left[] = $arr[$i];
} else {
$right[] = $arr[$i];
}
}
$left = quickSort($left);
$right = quickSort($right);
return array_merge($left, [$base], $right);
}
選擇排序
選擇一個值假設為最小,然後依次比較,發現比他小的就互換位置
function selectSort($arr)
{
$count = count($arr);
if ($count <= 1) return $arr;
for ($i = 0; $i < $count; $i++) {
//假設最小值位置
$p = $i;
//用假設的最小值$arr[$p]輪流比較,發現比他小的就互換
for ($j = $i + 1; $j < $count; $j++) {
if ($arr[$p] > $arr[$j]) {
$p = $j;
}
}
if ($p != $i) {
$tmp = $arr[$p];
$arr[$p] = $arr[$i];
$arr[$i] = $tmp;
}
}
return $arr;
}
查詢
二分查詢
二分查詢必須是一個排序好的陣列,每次拿陣列中間位置的值與目標進行比較
function binarySearch(array $arr, $target)
{
$low = 0;
$high = count($arr) - 1;
while ($low <= $high) {
$middle = floor(($high + $low) / 2);
if ( $arr[$middle] == $target ) {
return $middle;
} elseif ( $arr[$middle] < $target ) {
$low = $middle + 1;
} else {
$high = $middle - 1;
}
}
return false;
}
原文地址:https://www.cnblogs.com/luke44/p/php-sort-...
本作品採用《CC 協議》,轉載必須註明作者和本文連結