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

溫馨提示×

溫馨提示×

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

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

PHP中如何實現quicksort

發布時間:2021-08-12 15:05:53 來源:億速云 閱讀:144 作者:Leah 欄目:開發技術

這篇文章將為大家詳細講解有關PHP中如何實現quicksort,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

quicksort

在快速排序算法中,使用了分治策略。首先把序列分成兩個子序列,遞歸地對子序列進行排序,直到整個序列排序結束。(即一分為二的思想)

步驟如下:

在序列中選擇一個關鍵元素做為軸;

對序列進行重新排序,將比軸小的元素移到軸的前邊,比軸大的元素移動到軸的后面。在進行劃分之后,軸便在它最終的位置上;

遞歸地對兩個子序列進行重新排序:含有較小元素的子序列和含有較大元素的子序列。

比如序列$arr:

5 3 0 11 44 7 23 2 將第一個元素$arr[0] = 5 作為軸 設置標志位 low … top代表首尾
2 3 0 11 44 7 23 2 從相反方向(右)開始比較:2<5 將第一個位置替換為2,low++
2 3 0 11 44 7 23 11 從相反方向(左)開始比較直到:5<11 將最后一個位置替換為11,top–
重復以上步驟直到 low == top 把該位置替換為軸元素即5
2 3 0 5 44 7 23 11
這樣就可分為兩部分2 3 0 與 44 23 11
這樣就可以得出遞歸繼續開始步驟

算法實現:

class quick_sort{
    function quicksort(&$arr,$low,$top){
      if($low < $top){
        $pivotpos = $this->partition($arr,$low,$top);
        $this->quicksort($arr,$low,$pivotpos-1);
        $this->quicksort($arr,$pivotpos+1,$top);
      }
    }
    function partition(&$arr, $low ,$top){
      if($low == $top){
        return;
      }
  //   設置初始數值
      $com = $arr[$low];
      while($low!=$top){
  //      將比初始數值小的替換到左邊
        while($top&&$top!=$low){
          if($com > $arr[$top]){
          $arr[$low++] = $arr[$top];
          break;
          }else{
            $top--;
          }
        }
  //      將比初始數值大的替換到右邊
        while($low&&$low!=$top){
          if($com < $arr[$low]){
            $arr[$top--] = $arr[$low];
            break;
          }else{
            $low++;
          }
        }
      }
      $arr[$low] = $com;
      return $low;
    }
}

關于PHP中如何實現quicksort就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

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

AI

中西区| 彰化县| 五大连池市| 屏东市| 汨罗市| 县级市| 澄江县| 商城县| 汝南县| 锡林郭勒盟| 扎兰屯市| 四平市| 甘德县| 邹城市| 广饶县| 巴楚县| 阜新市| 嵊州市| 施甸县| 阿图什市| 登封市| 新丰县| 乌兰县| 延吉市| 菏泽市| 邵阳县| 资溪县| 乌鲁木齐市| 龙岩市| 威海市| 诸城市| 朝阳县| 乌拉特后旗| 古交市| 游戏| 涪陵区| 泗阳县| 博野县| 兴义市| 九江市| 贡嘎县|