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

溫馨提示×

溫馨提示×

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

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

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

安新县| 海伦市| 滨海县| 信丰县| 建瓯市| 建宁县| 诏安县| 丰宁| 博白县| 高青县| 汶川县| 阳新县| 兰坪| 莲花县| 清镇市| 科技| 大余县| 乐昌市| 崇信县| 东港市| 徐州市| 余江县| 缙云县| 仙居县| 兴化市| 大同市| 河曲县| 临江市| 温泉县| 巴南区| 婺源县| 临汾市| 尉犁县| 新邵县| 军事| 涪陵区| 平阳县| 呼图壁县| 通许县| 达尔| 宿松县|