亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

蓝田县| 石景山区| 井冈山市| 大荔县| 都安| 永昌县| 芜湖市| 永清县| 保靖县| 垦利县| 大连市| 肥城市| 渭南市| 瑞丽市| 古交市| 柳河县| 洪湖市| 海晏县| 武安市| 鄂托克旗| 苍山县| 合山市| 美姑县| 乌兰县| 彭阳县| 西吉县| 班玛县| 塔城市| 子长县| 兴安县| 民权县| 古田县| 泽州县| 平凉市| 合肥市| 洪洞县| 雅安市| 泗洪县| 邻水| 高陵县| 东宁县|