a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > Golang > 正文

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

2020-04-01 19:11:08
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Go語言展現快速排序算法全過程的思路及代碼示例,文章最后作者還提到了對Quick Sort算法優化的一些想法,需要的朋友可以參考下
 

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

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

選擇最右邊的數字作為基數。使用一個變量j記錄當前左邊數字(比基數小的數)的最右的下標值。然后使用變量i從左到右遍歷數組,如果a[i]比基數小,說明a[i]屬于左邊的數,就把j自增,然后交換a[j]和當前的a[i]。因為自增前的j是左邊數字最右的下標,自增后的a[j]肯定不屬于左邊了,把其跟a[i]交換后,新的a[j]是屬于左邊的,而且此時j也重新變為左邊數字最右的下標了。

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

Golang版的實現例子:

 

復制代碼代碼如下:

 

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 ;
}

 


執行輸出如下:

 

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

 

quicksort quicksort.go
[yu@argcandargv-com quicksort]$ time ./quicksort
Start ... 600000599999 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.564suser  1m55.215ssys 0m0.052s

PS:其實應用中有一個優化,因為快速排序在數組本來有序的情況下復雜度會退化為O(n^2)。為了避免這點,在選取基數的時候可以隨機地進行選擇。具體做法是把最右邊的數字跟一個隨機的數字交換位置。另外還有一種三數取中的方法,即選擇首尾跟中間某個數共三個數的中值作為基數。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丁香久久| 亚洲国产精品久久久久久 | 色福利影院 | 亚洲精品v日韩精品 | 久久99爱视频 | 久久精品国产一区 | 韩国av一区二区 | 国产精品一区二区三区四区 | 久久久久久久久久久久国产精品 | 97超碰人人在线 | 亚洲视频在线一区二区 | 久久久久久精 | 人人草人人看 | 亚洲国产情侣自拍 | 中文字幕第31页 | 中文字幕在线观看资源 | 久久99精品久久久久国产越南 | 久久国内免费视频 | 日韩一区二区三区在线播放 | 欧美淫片 | 国产激情在线视频 | 国产视频一区二区在线观看 | 91精品中文字幕一区二区三区 | 久久综合一区二区三区 | 午夜黄色影院 | 黄色免费观看网站 | www,99热| 欧美亚洲国产一区二区三区 | 亚洲欧洲精品成人久久奇米网 | 欧美男人的天堂 | 日韩视频一区 | 久久亚洲欧美日韩精品专区 | 日韩精品一区二区三区 | 欧美成人资源 | 伊人青青久 | 精品久久久久久一区二区 | 天天摸天天看 | 成人在线视频网站 | 免费欧美视频 | 国产免费一区二区 | 精品96久久久久久中文字幕无 |