中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

php如何實現并歸排序

發布時間:2022-10-24 16:27:33 來源:億速云 閱讀:365 作者:iii 欄目:編程語言

今天小編給大家分享一下php如何實現并歸排序的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

php實現并歸排序的方法:1、創建一個PHP示例文件;2、定義“public function handle(){...}”方法;3、通過“private function mergeSort($a, $lo, $hi) {...}”方法把數據逐步分解;4、通過“merge”方法對分解后的數據進行排序,再合并到一起即可。

php實現歸并排序算法

歸并排序算法的復雜度是O(nlogn)。

代碼如下,只需要clone下來執行composer install然后執行 php artisan test:mergeSort 就可以看到結果了

    /**
     * 歸并排序把數據逐步分解,然后對分解后的數據進行排序,最后合并到一起
     *
     * @return mixed
     */
    public function handle()
    {
        $this->a = [3,70,4,38,5,6,8,4,7,10,6,10,34,4];
        dump($this->a);
        $a = $this->mergeSort($this->a, 0, count($this->a));
        dd($a);
    }
    private function mergeSort($a, $lo, $hi) {
        if (($hi - $lo) < 2) return [$a[$lo]];
        $mi = ($lo + $hi) >> 1;
        //把中點左邊的進行歸并
        $b = $this->mergeSort($a, $lo, $mi);
        dump('$b:',$b);
        //把中點右邊的進行歸并
        $c = $this->mergeSort($a, $mi, $hi);
        dump('$c:',$c);
        //把所有數據進行排序
        return $this->merge($b, $c, $lo,$mi,$hi);
    }
    /**
     * 假設有一個數組$a分成了兩個數組[3,4] [2,8]
     * 逐一比較,3and2,取出來2然后3and8取出來3然后4and8取出來4,最后取出來8
     *
     * @param [type] $lo
     * @param [type] $mi
     * @param [type] $hi
     * @return void
     */
    private function merge($b, $c, $lo, $mi, $hi) {
        $lb = $mi - $lo; //$b數組的邊界
        $lc = $hi - $mi; //$c數組的邊界
        $res = [];
        //$i表示合并后數組的下標 $ib是b數組的下標 $ic是c數組的下標 
        for($i = 0,$ib=0,$ic=0;$ib<$lb || $ic < $lc;){
            //ib 下標沒有越界 && c的數組已經空了也就是$ic >= $lc || 比較兩個數組首位的大小 如果b的首元素 < c的首元素,那么取出來b的首元素
            if ($ib < $lb && ( $ic >= $lc || $b[$ib] <= $c[$ic])) {
                $res[$i++] = $b[$ib++];
            }
            //k 下標沒有越界 && b的數組已經空了也就是$ib >= $lb || 如果c的首元素 < b的首元素,那么取出來c的首元素 
            if ($ic < $lc && ($ib >= $lb || $b[$ib] > $c[$ic])) {
                $res[$i++] = $c[$ic++];
            }
        }
        return $res;
    }

歸并排序原理

歸并排序和快排剛好相反,是先將整個數組左右打散,然后在逐一合并進行排序,最終完成整個數組的排序,排序示意圖如下:

php如何實現并歸排序

首先將整個數組左右打散,變成單個元素,因為單個元素可以被認為是有序的。

對應代碼

if (($hi - $lo) < 2) return [$a[$lo]];
$mi = ($lo + $hi) >> 1;
//把中點左邊的進行歸并
$b = $this->mergeSort($a, $lo, $mi);
dump('$b:',$b);
//把中點右邊的進行歸并
$c = $this->mergeSort($a, $mi, $hi);
dump('$c:',$c);

接下來對左右兩個有序數組進行排序,假設有一個數組$a分成了兩個數組[3,4] [2,8],逐一比較,3and2,取出來2然后3and8取出來3然后4and8取出來4,最后取出來8,對應代碼:

$lb = $mi - $lo; //$b數組的邊界
$lc = $hi - $mi; //$c數組的邊界
$res = [];
//$i表示合并后數組的下標 $ib是b數組的下標 $ic是c數組的下標 
for($i = 0,$ib=0,$ic=0;$ib<$lb || $ic < $lc;){
    //ib 下標沒有越界 && c的數組已經空了也就是$ic >= $lc || 比較兩個數組首位的大小 如果b的首元素 < c的首元素,那么取出來b的首元素
    if ($ib < $lb && ( $ic >= $lc || $b[$ib] <= $c[$ic])) {
        $res[$i++] = $b[$ib++];
    }
    //k 下標沒有越界 && b的數組已經空了也就是$ib >= $lb || 如果c的首元素 < b的首元素,那么取出來c的首元素 
    if ($ic < $lc && ($ib >= $lb || $b[$ib] > $c[$ic])) {
        $res[$i++] = $c[$ic++];
    }
}
return $res;

示意圖如下:

php如何實現并歸排序

以上就是“php如何實現并歸排序”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

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

php
AI

观塘区| 育儿| 桃园县| 马尔康县| 林芝县| 渭南市| 南溪县| 江永县| 凤阳县| 大宁县| 信宜市| 深圳市| 繁峙县| 霍城县| 封开县| 五家渠市| 城口县| 克什克腾旗| 额敏县| 嘉善县| 开平市| 奉节县| 仁寿县| 贵港市| 西华县| 道孚县| 濮阳县| 什邡市| 安溪县| 安平县| 葵青区| 南充市| 图片| 三亚市| 泸溪县| 元氏县| 都安| 牟定县| 无为县| 剑河县| 奈曼旗|