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

C++/GoLang如何實(shí)現(xiàn)自底向上的歸并排序

 更新時(shí)間:2020年08月30日 10:57:15   作者:NothingLeft了  
這篇文章主要給大家介紹了關(guān)于C++/GoLang如何實(shí)現(xiàn)自底向上的歸并排序的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

上一篇文章寫(xiě)了一個(gè)自頂向下的歸并排序,把一個(gè)完整的數(shù)組不斷二分,然后再合并。其實(shí)換一種思路:把數(shù)組中相鄰的N個(gè)元素看成是已經(jīng)二分好了的,直接進(jìn)行合并,就省掉了二分那一步驟

C++實(shí)現(xiàn):

template<typename T>
void mergeSortButton2Top(T arr[], int n) {
 for (int size = 1; size <= n; size += size) {
 for (int i = 0; i+size < n; i+=2*size) //對(duì)[i,i+size-1]和[i+size,i+2*size-1]進(jìn)行歸并
 __merge(arr, i, i + size - 1, min(i + size + size - 1,n-1));// arr left mid right 如果i+2*size>n了,越界了,就取n-1
 }
}

template<typename T>
void __merge(T arr[], int left, int mid, int right) { //將arr[left,mid] 和 arr[mid+1,right] 兩部分進(jìn)行歸并

 T *tmp=new T[right-left+1];
 for (int i = left; i <= right; i++)
 tmp[i - left] = arr[i]; //先把a(bǔ)rr(需要合并的左右片段) 復(fù)制給tmp

 int i = left, j = mid + 1; // i 做為左半部分的指針 j作為右半部分的指針
 for (int k = left; k <= right; k++) {
 if (i > mid) { // 左半部分 已經(jīng)合入完了,將右半部分剩下的 全部合入
 arr[k] = tmp[j - left];
 j++;
 }
 else if (j > right) { // 右半部分 已經(jīng)合入完了,將左半部分剩下的 全部合入
 arr[k] = tmp[i - left];
 i++;
 }
 else if (tmp[i - left] < tmp[j - left]) {
 arr[k] = tmp[i - left];
 i++;
 }
 else {
 arr[k] = tmp[j - left];
 j++;
 }
 }
 delete[] tmp;
}

int main() {
 int arr[9] = { 1,5,6,78,12,5,1,12,54 };
 mergeSortButton2Top(arr,9);
 for (int i = 0; i < 9; i++) {
 cout << arr[i]<<" ";
 }
 return 0;
}

GoLang實(shí)現(xiàn):

func mergeSortButton2Top(arr [] int) {
 var lenth int = len(arr)
 for size := 1; size <= lenth; size += size {
 for i := 0; i+size < lenth; i += 2 * size { //對(duì)[i,i+size-1]和[i+size,i+2*size-1]進(jìn)行歸并
  merge(arr, i, i+size-1, int(math.Min(float64(i+2*size-1), float64(lenth-1))))// arr left mid right 如果i+2*size>n了,越界了,就取n-1
 }
 }
}

func merge(arr []int, left, mid, right int) {
 // 將要合并的部分做個(gè)拷貝
 var tmp []int = make([]int, right-left+1)
 for i, j := left, 0; i <= right; i++ {
 tmp[j] = arr[i]
 j++
 }
 // i做為左半部分的指針 j作為右半部分的指針
 var i, j int = left, mid+1
 for k := left; k <= right; k++ {
 if i > mid { // 左半部分 已經(jīng)合入完了,將右半部分剩下的 全部合入
  arr[k] = tmp[j-left]
  j++
 } else if j > right { // 右半部分 已經(jīng)合入完了,將左半部分剩下的 全部合入
  arr[k] = tmp[i-left]
  i++
 } else if tmp[i-left] > tmp[j-left] {
  arr[k] = tmp[j-left]
  j++
 } else {
  arr[k] = tmp[i-left]
  i++
 }
 }
}

用golang對(duì)兩種歸并排序進(jìn)行計(jì)時(shí),觀察性能:

func createRandomArray(count int) []int {
 rand.Seed(time.Now().UnixNano())
 var arr [] int = make([]int, 0)
 for i := 0; i < count; i++ {
 arr = append(arr, rand.Intn(100))
 }
 return arr
}

func main() {
 count := 10000
 arr := createRandomArray(count)
 var arr2 []int = make([]int, count)
 copy(arr2, arr)
 start := time.Now()
 mergeSort(arr, 0, len(arr)-1)
 fmt.Println("自頂向下歸并排序 用時(shí):", time.Since(start))

 start = time.Now()
 mergeSortButton2Top(arr2)
 fmt.Println("自底向上歸并排序 用時(shí):", time.Since(start))
}

//輸出:
//自頂向下歸并排序 用時(shí): 4.997ms
//自底向上歸并排序 用時(shí): 3.9987ms

因?yàn)樽缘紫蛏仙倭硕帜莻€(gè)步驟,性能要優(yōu)于自頂向下的歸并排序

總結(jié)

到此這篇關(guān)于C++/GoLang如何實(shí)現(xiàn)自底向上的歸并排序的文章就介紹到這了,更多相關(guān)C++/GoLang自底向上的歸并排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 簡(jiǎn)單了解C++常見(jiàn)編程問(wèn)題解決方案

    簡(jiǎn)單了解C++常見(jiàn)編程問(wèn)題解決方案

    這篇文章主要介紹了C++常見(jiàn)編程問(wèn)題解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • C++遞歸實(shí)現(xiàn)螺旋數(shù)組的實(shí)例代碼

    C++遞歸實(shí)現(xiàn)螺旋數(shù)組的實(shí)例代碼

    這篇文章主要介紹了C++遞歸實(shí)現(xiàn)螺旋數(shù)組的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04
  • C/C++實(shí)現(xiàn)Windows注冊(cè)表的基本操作

    C/C++實(shí)現(xiàn)Windows注冊(cè)表的基本操作

    Windows注冊(cè)表(Registry)是Windows操作系統(tǒng)中用于存儲(chǔ)系統(tǒng)配置信息、用戶(hù)設(shè)置和應(yīng)用程序數(shù)據(jù)的一個(gè)集中式數(shù)據(jù)庫(kù),本文主要為大家介紹了C++對(duì)注冊(cè)表的基本操作,感興趣的小伙伴可以了解下
    2023-11-11
  • C語(yǔ)言快速排序函數(shù)用法(qsort)

    C語(yǔ)言快速排序函數(shù)用法(qsort)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言的快排函數(shù)用法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • C++輸入一個(gè)字符串,把其中的字符按照逆序輸出的兩種方法解析

    C++輸入一個(gè)字符串,把其中的字符按照逆序輸出的兩種方法解析

    以下是對(duì)C++中輸入一個(gè)字符串,把其中的字符按照逆序輸出的兩種方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-07-07
  • 詳解C語(yǔ)言中free()函數(shù)與getpagesize()函數(shù)的使用

    詳解C語(yǔ)言中free()函數(shù)與getpagesize()函數(shù)的使用

    這篇文章主要介紹了詳解C語(yǔ)言中free()函數(shù)與getpagesize()函數(shù)的使用,是C語(yǔ)言入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-08-08
  • C++深入細(xì)致探究二叉搜索樹(shù)

    C++深入細(xì)致探究二叉搜索樹(shù)

    二叉搜索樹(shù)是以一棵二叉樹(shù)來(lái)組織的。每個(gè)節(jié)點(diǎn)是一個(gè)對(duì)象,包含的屬性有l(wèi)eft,right,p和key,其中,left指向該節(jié)點(diǎn)的左孩子,right指向該節(jié)點(diǎn)的右孩子,p指向該節(jié)點(diǎn)的父節(jié)點(diǎn),key是它的值
    2022-05-05
  • C語(yǔ)言修煉之路靈根孕育源流出?初識(shí)C言大道生上篇

    C語(yǔ)言修煉之路靈根孕育源流出?初識(shí)C言大道生上篇

    C語(yǔ)言是一門(mén)面向過(guò)程、抽象化的通用程序設(shè)計(jì)語(yǔ)言,廣泛應(yīng)用于底層開(kāi)發(fā)。C語(yǔ)言能以簡(jiǎn)易的方式編譯、處理低級(jí)存儲(chǔ)器。C語(yǔ)言是僅產(chǎn)生少量的機(jī)器語(yǔ)言以及不需要任何運(yùn)行環(huán)境支持便能運(yùn)行的高效率程序設(shè)計(jì)語(yǔ)言
    2022-03-03
  • C++深入刨析優(yōu)先級(jí)隊(duì)列priority_queue的使用

    C++深入刨析優(yōu)先級(jí)隊(duì)列priority_queue的使用

    最近我學(xué)習(xí)了C++中的STL庫(kù)中的優(yōu)先級(jí)隊(duì)列(priority_queue)容器適配器,對(duì)于優(yōu)先級(jí)隊(duì)列,我們不僅要會(huì)使用常用的函數(shù)接口,我們還有明白這些接口在其底層是如何實(shí)現(xiàn)的
    2022-08-08
  • C語(yǔ)言實(shí)現(xiàn)彈跳小球動(dòng)畫(huà)

    C語(yǔ)言實(shí)現(xiàn)彈跳小球動(dòng)畫(huà)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)彈跳小球動(dòng)畫(huà),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05

最新評(píng)論