两个吃奶一个添下面视频_人妻第一页香蕉网_欧美xxxx少妇_妺妺窝人体色www婷婷

快速排序(Quick Sort)是基于二分思想,對(duì)冒泡排序的一種改進(jìn)。主要思想是確立一個(gè)基數(shù),將小于基數(shù)的數(shù)字放到基數(shù)的左邊,大于基數(shù)的數(shù)字放到基數(shù)的右邊,然后再對(duì)這兩部分?jǐn)?shù)字進(jìn)一步排序,從而實(shí)現(xiàn)對(duì)數(shù)組的排序。


優(yōu)點(diǎn)是效率高,時(shí)間復(fù)雜度平均為O(nlogn),顧名思義,快速排序是最快的排序算法,耗費(fèi)的資源少,最佳情況下,空間復(fù)雜度為O(logn),每一次都平分?jǐn)?shù)組的情況,代碼較為簡(jiǎn)單。


缺點(diǎn)是不穩(wěn)定,初始序列有序或基本有序時(shí),時(shí)間復(fù)雜度降為O(n^2)。


例如:

public class Main {
    //快排實(shí)現(xiàn)方法
    public static void quickRow(int[] array,int low,int high) {
        int i,j,pivot;
        //結(jié)束條件
        if(low >= high) {
            return;
        }
        i = low;
        j = high;
        //選擇的節(jié)點(diǎn),這里選擇的數(shù)組的第一數(shù)作為節(jié)點(diǎn)
        pivot = array[low];
        while(i<j) {
            //從右往左找比節(jié)點(diǎn)小的數(shù),循環(huán)結(jié)束要么找到了,要么i=j
            while(array[j] >= pivot && i<j) {
                j--;
            }
            //從左往右找比節(jié)點(diǎn)大的數(shù),循環(huán)結(jié)束要么找到了,要么i=j
            while(array[i] <= pivot && i<j) {
                i++;
            }
            //如果i!=j說(shuō)明都找到了,就交換這兩個(gè)數(shù)
            if(i<j) {
                int temp = array[i];
                array[i] = array[j];
                array[j] = temp;
            }
        }
        //i==j一輪循環(huán)結(jié)束,交換節(jié)點(diǎn)的數(shù)和相遇點(diǎn)的數(shù)
        array[low] = array[i];
        array[i] = pivot;
        //數(shù)組“分兩半”,再重復(fù)上面的操作
        quickRow(array,low,i-1);
        quickRow(array,i+1,high);
    }
    public static void main(String[] args) {
        int[] array = {6,17,38,59,2,10};
        int low = 0,high = array.length-1;
        quickRow(array,low,high);
        for (int i : array){
            System.out.println(i);
        }
    }
}


運(yùn)行結(jié)果如下:

2
6
10
17
38
59


點(diǎn)贊(0)

C語(yǔ)言網(wǎng)提供由在職研發(fā)工程師或ACM藍(lán)橋杯競(jìng)賽優(yōu)秀選手錄制的視頻教程,并配有習(xí)題和答疑,點(diǎn)擊了解:

一點(diǎn)編程也不會(huì)寫(xiě)的:零基礎(chǔ)C語(yǔ)言學(xué)練課程

解決困擾你多年的C語(yǔ)言疑難雜癥特性的C語(yǔ)言進(jìn)階課程

從零到寫(xiě)出一個(gè)爬蟲(chóng)的Python編程課程

只會(huì)語(yǔ)法寫(xiě)不出代碼?手把手帶你寫(xiě)100個(gè)編程真題的編程百練課程

信息學(xué)奧賽或C++選手的 必學(xué)C++課程

藍(lán)橋杯ACM、信息學(xué)奧賽的必學(xué)課程:算法競(jìng)賽課入門(mén)課程

手把手講解近五年真題的藍(lán)橋杯輔導(dǎo)課程

Dotcpp在線編譯      (登錄可減少運(yùn)行等待時(shí)間)