91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP怎么實現幾個排序和查找算法

發布時間:2020-10-15 17:52:06 來源:億速云 閱讀:118 作者:小新 欄目:編程語言

小編給大家分享一下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;
}

以上是PHP怎么實現幾個排序和查找算法的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

保定市| 田阳县| 株洲县| 彰化市| 海城市| 太白县| 东莞市| 万山特区| 贵阳市| 崇阳县| 中卫市| 潮州市| 三江| 宁波市| 怀化市| 阿鲁科尔沁旗| 西平县| 海晏县| 瑞安市| 朝阳县| 吉水县| 余江县| 海门市| 永泰县| 崇明县| 正定县| 女性| 宁南县| 罗定市| 乡宁县| 东光县| 都匀市| 宁海县| 丰镇市| 云南省| 南城县| 精河县| 全椒县| 杂多县| 嘉定区| 宜川县|