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

Go語言展現(xiàn)快速排序算法全過程的思路及代碼示例

 更新時間:2016年04月13日 10:55:53   作者:荊榆  
這篇文章主要介紹了Go語言展現(xiàn)快速排序算法全過程的思路及代碼示例,文章最后作者還提到了對Quick Sort算法優(yōu)化的一些想法,需要的朋友可以參考下

快速排序算法
快速排序是一個遞歸的思想,首先選擇一個數(shù)作為基數(shù),把數(shù)組中小于它的數(shù)放在它的左邊,把大于它的數(shù)放在它的右邊,然后對左右兩邊的數(shù)遞歸進(jìn)行排序。

算法的關(guān)鍵部分是實(shí)現(xiàn)數(shù)組的劃分,即怎么把數(shù)組的元素劃分成兩部分,使得左邊的數(shù)比基數(shù)小,右邊的數(shù)比基數(shù)大。劃分有許多不同的實(shí)現(xiàn)方法,這里主要使用單向掃描的方法,后面再稍微介紹雙向掃描的方法。

選擇最右邊的數(shù)字作為基數(shù)。使用一個變量j記錄當(dāng)前左邊數(shù)字(比基數(shù)小的數(shù))的最右的下標(biāo)值。然后使用變量i從左到右遍歷數(shù)組,如果a[i]比基數(shù)小,說明a[i]屬于左邊的數(shù),就把j自增,然后交換a[j]和當(dāng)前的a[i]。因?yàn)樽栽銮暗膉是左邊數(shù)字最右的下標(biāo),自增后的a[j]肯定不屬于左邊了,把其跟a[i]交換后,新的a[j]是屬于左邊的,而且此時j也重新變?yōu)樽筮厰?shù)字最右的下標(biāo)了。

掃描結(jié)束后,把j自增(因?yàn)閍[j]將會被交換到最右邊,因此要選屬于右邊的數(shù)字)后與最右邊的基數(shù)交換,此時的j即為劃分的結(jié)果。

Golang版的實(shí)現(xiàn)例子:

復(fù)制代碼 代碼如下:

package main
import "fmt"
 
type ElemType int;
 
func main() {
    data := make([]ElemType, 600000) // ALL ZERO
    var i int = 0;
    var dlen int = len(data);
    for i = 0 ; i < dlen ; i++{
        data[i] = (ElemType)(dlen - i -1);
    }
    fmt.Println("Start ...",len(data));
    for i = 0 ; i < 100 ; i++{
        fmt.Printf("%d ", data[i]);
    }
    fmt.Println();
    QuickSort(data,0,dlen-1);
    
    fmt.Println("End ...");
    for i = 0 ; i < 100 ; i++{
        fmt.Printf("%d ", data[i]);
    }
    fmt.Println();
}
 
func QuickSort(A []ElemType,low, high int){
    if low < high {
        // Partition() is the operation of divide A[low ... high]
        // one to two arrays which can be used as QuickSort Again
        pivotpos := Partition(A,low,high);
        QuickSort(A,low,pivotpos-1);
        QuickSort(A,pivotpos+1,high);
    }
}
 
func Partition(A []ElemType,low ,high int)  int {
    var pivot ElemType = A[low];
    var tmp ElemType;
    //Method I:
    //for low < high {
    //  for low < high && A[high] >= pivot { high-- ; }
    //  A[low] = A[high];
    //  for low < high && A[low] < pivot { low++; }
    //  A[high] = A[low];
    //}
    //end of MI
    
    //Method II:
    for (low < high) && (A[high] > pivot) { high --; }
    for (low < high) && (A[low] < pivot) {low++; }
    for low < high {
        // swap A[low] & A[high]
        tmp = A[low];
        A[low] = A[high];
        A[high] = tmp;
        low ++;
        high --;
    }
    //end of MII
 
    A[low] = pivot ;
    return low ;
}


執(zhí)行輸出如下:

[yu@argcandargv-com quicksort]$ go build quicksort.go 
[yu@argcandargv-com quicksort]$ ls

quicksort quicksort.go
[yu@argcandargv-com quicksort]$ time ./quicksort
Start ... 600000
599999 599998 599997 599996 599995 599994 599993 599992 599991 599990 599989 599988 599987 599986 599985 599984 599983 599982 599981 599980 599979 599978 599977 599976 599975 599974 599973 599972 599971 599970 599969 599968 599967 599966 599965 599964 599963 599962 599961 599960 599959 599958 599957 599956 599955 599954 599953 599952 599951 599950 599949 599948 599947 599946 599945 599944 599943 599942 599941 599940 599939 599938 599937 599936 599935 599934 599933 599932 599931 599930 599929 599928 599927 599926 599925 599924 599923 599922 599921 599920 599919 599918 599917 599916 599915 599914 599913 599912 599911 599910 599909 599908 599907 599906 599905 599904 599903 599902 599901 599900 
End ...
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 

 

real  1m55.564s
user  1m55.215s
sys 0m0.052s

PS:其實(shí)應(yīng)用中有一個優(yōu)化,因?yàn)榭焖倥判蛟跀?shù)組本來有序的情況下復(fù)雜度會退化為O(n^2)。為了避免這點(diǎn),在選取基數(shù)的時候可以隨機(jī)地進(jìn)行選擇。具體做法是把最右邊的數(shù)字跟一個隨機(jī)的數(shù)字交換位置。另外還有一種三數(shù)取中的方法,即選擇首尾跟中間某個數(shù)共三個數(shù)的中值作為基數(shù)。

相關(guān)文章

  • 自己動手用Golang實(shí)現(xiàn)約瑟夫環(huán)算法的示例

    自己動手用Golang實(shí)現(xiàn)約瑟夫環(huán)算法的示例

    這篇文章主要介紹了自己動手用Golang實(shí)現(xiàn)約瑟夫環(huán)算法的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • go語言題解LeetCode1299將每個元素替換為右側(cè)最大元素

    go語言題解LeetCode1299將每個元素替換為右側(cè)最大元素

    這篇文章主要為大家介紹了go語言LeetCode刷題1299將每個元素替換為右側(cè)最大元素示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • Golang?WaitGroup?底層原理及源碼解析

    Golang?WaitGroup?底層原理及源碼解析

    WaitGroup?是?Golang?中最常見的并發(fā)控制技術(shù)之一,它的作用我們可以簡單類比為其他語言中多線程并發(fā)控制中的?join(),這篇文章主要介紹了Golang?WaitGroup?底層原理及源碼詳解,需要的朋友可以參考下
    2023-04-04
  • 深入了解Go語言中sync.Pool的使用

    深入了解Go語言中sync.Pool的使用

    本文將介紹?Go?語言中的?sync.Pool并發(fā)原語,包括sync.Pool的基本使用方法、使用注意事項(xiàng)等的內(nèi)容,對我們了解Go語言有一定的幫助,需要的可以參考一下
    2023-04-04
  • 詳解golang中發(fā)送http請求的幾種常見情況

    詳解golang中發(fā)送http請求的幾種常見情況

    這篇文章主要介紹了詳解golang中發(fā)送http請求的幾種常見情況,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • golang如何實(shí)現(xiàn)抓取IP地址的蜘蛛程序詳解

    golang如何實(shí)現(xiàn)抓取IP地址的蜘蛛程序詳解

    這篇文章主要給大家介紹了關(guān)于利用golang如何實(shí)現(xiàn)抓取IP地址的蜘蛛程序的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07
  • Golang開發(fā)中如何解決共享變量問題

    Golang開發(fā)中如何解決共享變量問題

    Go提供了傳統(tǒng)通過共享變量,也就是共享內(nèi)存的方式來實(shí)現(xiàn)并發(fā)。這篇文章會介紹 Go提供的相關(guān)機(jī)制,對Golang共享變量相關(guān)知識感興趣的朋友一起看看吧
    2021-09-09
  • 手把手帶你走進(jìn)Go語言之語法基礎(chǔ)解析

    手把手帶你走進(jìn)Go語言之語法基礎(chǔ)解析

    這篇文章主要介紹了手把手帶你走進(jìn)Go語言之語法基礎(chǔ),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • 使用Go中的Web3庫進(jìn)行區(qū)塊鏈開發(fā)的案例

    使用Go中的Web3庫進(jìn)行區(qū)塊鏈開發(fā)的案例

    區(qū)塊鏈作為一種分布式賬本技術(shù),在近年來取得了巨大的發(fā)展,而Golang作為一種高效、并發(fā)性強(qiáng)的編程語言,被廣泛用于區(qū)塊鏈開發(fā)中,本文將介紹如何使用Golang中的Web3庫進(jìn)行區(qū)塊鏈開發(fā),并提供一些實(shí)際案例,需要的朋友可以參考下
    2023-10-10
  • golang高并發(fā)的深入理解

    golang高并發(fā)的深入理解

    golang從語言級別上對并發(fā)提供了支持,而且在啟動并發(fā)的方式上直接添加了語言級的關(guān)鍵字。下面這篇文章主要給大家介紹了關(guān)于golang高并發(fā)的相關(guān)資料,需要的朋友可以參考下
    2019-03-03

最新評論