亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

[PHP] 算法-快速排序的PHP實現

標簽:
PHP

 

快速排序:
1.基于二分的思想2.第一个作为基准数,左右各一个指针,同时扫描,右边先走,找到比基准数小的停下
左边再走,找到比基准数大的停下,左右交换3.当左右相遇的时候,把当前的和基准数调换,递归调用4.快速排序的最差时间复杂度和冒泡排序是一样的都是O(N2),它的平均时间复杂度为O(NlogN)

quickSort &arr,left,right    if left>right return
    temp=arr[left]
    i=left
    j=right    while i<j        while arr[j]>=temp && i<j
            j--        while arr[i]<=temp && i<j
            i++
        t=arr[i]
        a[i]=arr[j]
        a[j]=t;
    arr[left]=arr[i]
    arr[i]=temp

    quickSort(arr,left,i-1)
    quickSort(arr,i+1,right)

复制代码

 

复制代码

<?php//快速排序function quickSort(&$arr,$left,$right){        //left大于right的就退出
        if($left>$right) return;        //选第一个为基准数
        $temp=$arr[$left];        //i是左边的指针
        $i=$left;        //j是右边的指针
        $j=$right;        //i小于j的时候一直循环
        while($i<$j){                //j从右往左走,大于等于基准数就往前走一步,并且最终j会等于i
                while($arr[$j]>=$temp && $i<$j){                        $j--;
                }   
                //i从左往右走,小于等于基准数的就往前走一步,最终i会等于j
                while($arr[$i]<=$temp && $i<$j){                        $i++;
                }   
                //调换i和j所在的数
                $t=$arr[$i];                $arr[$i]=$arr[$j];                $arr[$j]=$t;
        }   
        //基准数和i,j所在的位置的数调换位置
        $arr[$left]=$arr[$i];        $arr[$i]=$temp;        //左半部分递归
        quickSort($arr,$left,$i-1);        //右半部分递归
        quickSort($arr,$i+1,$right);
}$arr=array(9,3,5,1,7,9,6,2,4,8,0);$right=count($arr)-1;
quickSort($arr,0,$right);var_dump($arr);

复制代码

原文出处:https://www.cnblogs.com/taoshihan/p/9687303.html 

點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消