面試常問的幾個排序和查詢演算法,PHP 實現

lukedever發表於2019-03-08

冒泡,快排,二分查詢,都是面試常問的幾個演算法題目,雖然簡單,但是一段時間不用的話就很容易忘記,這裡我用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 協議》,轉載必須註明作者和本文連結

相關文章