欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP遞歸實現(xiàn)快速排序的方法示例

 更新時間:2017年12月18日 14:09:51   作者:純敬  
這篇文章主要介紹了PHP遞歸實現(xiàn)快速排序的方法,簡單描述了快速排序的原理并結(jié)合實例形式分析了php使用遞歸算法實現(xiàn)快速排序的相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了PHP遞歸實現(xiàn)快速排序的方法。分享給大家供大家參考,具體如下:

首先我們要理解一下快速排序的原理找到當(dāng)前數(shù)組中的任意一個元素(一般選擇第一個元素),作為標(biāo)準(zhǔn),新建兩個空數(shù)組,遍歷整個數(shù)組元素,如果遍歷到的元素比當(dāng)前的元素要小,那么就放到左邊的數(shù)組,否則放到右面的數(shù)組,然后再對新數(shù)組進行同樣的操作。

不難發(fā)現(xiàn),這里符合遞歸的原理,所以我們可以用遞歸來實現(xiàn)。

使用遞歸,則需要找到遞歸點和遞歸出口:

遞歸點:如果數(shù)組的元素大于1,就需要再進行分解,所以我們的遞歸點就是新構(gòu)造的數(shù)組元素個數(shù)大于1

遞歸出口:我們什么時候不需要再對新數(shù)組不進行排序了呢?就是當(dāng)數(shù)組元素個數(shù)變成1的時候,所以這就是我們的出口。

理解了原理,來看一下代碼實現(xiàn)~

<?php
//快速排序
//待排序數(shù)組
$arr=array(6,3,8,6,4,2,9,5,1);
//函數(shù)實現(xiàn)快速排序
function quick_sort($arr)
{
    //判斷參數(shù)是否是一個數(shù)組
    if(!is_array($arr)) return false;
    //遞歸出口:數(shù)組長度為1,直接返回數(shù)組
    $length=count($arr);
    if($length<=1) return $arr;
    //數(shù)組元素有多個,則定義兩個空數(shù)組
    $left=$right=array();
    //使用for循環(huán)進行遍歷,把第一個元素當(dāng)做比較的對象
    for($i=1;$i<$length;$i++)
    {
      //判斷當(dāng)前元素的大小
      if($arr[$i]<$arr[0]){
        $left[]=$arr[$i];
      }else{
        $right[]=$arr[$i];
      }
    }
    //遞歸調(diào)用
    $left=quick_sort($left);
    $right=quick_sort($right);
    //將所有的結(jié)果合并
    return array_merge($left,array($arr[0]),$right);
}
//調(diào)用
echo "<pre>";
print_r(quick_sort($arr));

運行結(jié)果:

Array
(
  [0] => 1
  [1] => 2
  [2] => 3
  [3] => 4
  [4] => 5
  [5] => 6
  [6] => 6
  [7] => 8
  [8] => 9
)

PS:這里再為大家推薦一款關(guān)于排序的演示工具供大家參考:

在線動畫演示插入/選擇/冒泡/歸并/希爾/快速排序算法過程工具:
http://tools.jb51.net/aideddesign/paixu_ys

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php排序算法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運算技巧總結(jié)

希望本文所述對大家PHP程序設(shè)計有所幫助。

相關(guān)文章

  • php實現(xiàn)的操作excel類詳解

    php實現(xiàn)的操作excel類詳解

    這篇文章主要介紹了php實現(xiàn)的操作excel類,較為詳細(xì)的分析說明了PHP操作excel的具體技巧,包括PHP針對excel的創(chuàng)建、打開、讀取、修改等,需要的朋友可以參考下
    2016-01-01
  • CentOS6.5 編譯安裝lnmp環(huán)境

    CentOS6.5 編譯安裝lnmp環(huán)境

    這篇文章主要介紹了CentOS6.5 編譯安裝lnmp環(huán)境的相關(guān)資料及方法,需要的朋友可以參考下
    2014-12-12
  • 利用discuz實現(xiàn)PHP大文件上傳應(yīng)用實例代碼

    利用discuz實現(xiàn)PHP大文件上傳應(yīng)用實例代碼

    論壇的附件功能當(dāng)初設(shè)計的初衷并不是為了文件管理,由于服務(wù)器配置,php,網(wǎng)絡(luò)等多方面因素,使得通過論壇上傳文件并不是一個好方案。
    2008-11-11
  • PHP基于DOMDocument解析和生成xml的方法分析

    PHP基于DOMDocument解析和生成xml的方法分析

    這篇文章主要介紹了PHP基于DOMDocument解析和生成xml的方法,結(jié)合具體實例形式分析了php使用DOMDocument解析xml節(jié)點及xml文件生成的各種常用操作技巧,需要的朋友可以參考下
    2017-07-07
  • PHP STRING 陷阱原理說明

    PHP STRING 陷阱原理說明

    需要注意的時候,我們訪問數(shù)組的時候 都是使用方括號“[]”,string作為一個也可以使用操作符“[]”進行訪問。但是,需要注意的一點就是,訪問字符串時候,操作符“[]”中的內(nèi)容會被轉(zhuǎn)化為int類型的。
    2010-07-07
  • PHP進行批量任務(wù)處理不超時的解決方法

    PHP進行批量任務(wù)處理不超時的解決方法

    這篇文章主要介紹了PHP進行批量任務(wù)處理不超時的解決方法,結(jié)合實例形式簡單分析了php結(jié)合ajax進行異步處理實現(xiàn)批量任務(wù)不超時的相關(guān)技巧,需要的朋友可以參考下
    2016-07-07
  • PHP框架Laravel的小技巧兩則

    PHP框架Laravel的小技巧兩則

    這篇文章主要介紹了PHP框架Laravel的小技巧兩則,本文講解了Route::controller中路由批量命名、根據(jù)系統(tǒng)變量判斷當(dāng)前運行環(huán)境兩個小技巧,需要的朋友可以參考下
    2015-02-02
  • PHP+MYSQL中文亂碼問題

    PHP+MYSQL中文亂碼問題

    這篇文章主要匯總介紹了幾種解決PHP+MYSQL中文亂碼問題的方法,十分的實用,有需要的小伙伴可以參考下。
    2015-07-07
  • php實現(xiàn)快速排序法函數(shù)代碼

    php實現(xiàn)快速排序法函數(shù)代碼

    取一個值與其他值進行比較,小的放在這個值的左邊,大的放在這個值的右邊,然后按照這個方式遞歸
    2012-08-08
  • PHP高并發(fā)和大流量解決方案整理

    PHP高并發(fā)和大流量解決方案整理

    在本篇文章里小編給大家分享的是一篇關(guān)于PHP高并發(fā)和大流量解決方案內(nèi)容,有興趣的朋友們可以參考下。
    2019-12-12

最新評論