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

基于Go語言實現(xiàn)選擇排序算法及優(yōu)化

 更新時間:2022年12月09日 09:04:05   作者:陳明勇  
選擇排序是一種簡單的比較排序算法.這篇文章將利用Go語言實現(xiàn)冒泡排序算法,文中的示例代碼講解詳細(xì),對學(xué)習(xí)Go語言有一定的幫助,需要的可以參考一下

選擇排序

選擇排序是一種簡單的比較排序算法,它的算法思路是首先從數(shù)組中尋找最小(大)的元素,然后放到數(shù)組中的第一位,接下來繼續(xù)從未排序的元素中尋找最?。ù螅┰?,然后放到已排序元素的末尾,依次類推,直到所有元素被排序。

圖片演示

普通算法

import "fmt"

func main() {
    nums := [8]int{8, 2, 3, 1, 6, 5, 7, 4}
    fmt.Println("原數(shù)組:", nums)
    fmt.Println("--------------------------------")
    SelectionSort(nums)
}

func SelectionSort(nums [8]int) {
    for i := 0; i < len(nums)-1; i++ {
        minPos := i
        for j := i + 1; j < len(nums); j++ {
            if nums[minPos] > nums[j] {
                    minPos = j
            }
        }
        nums[i], nums[minPos] = nums[minPos], nums[i]
        fmt.Printf("第 %d 輪后:%v\n", i+1, nums)
    }
    fmt.Println("--------------------------------")
    fmt.Println("排序后的數(shù)組:", nums)
}

執(zhí)行結(jié)果:

原數(shù)組: [8 2 3 1 6 5 7 4]
--------------------------------
第 1 輪后:[1 2 3 8 6 5 7 4]
第 2 輪后:[1 2 3 8 6 5 7 4]
第 3 輪后:[1 2 3 8 6 5 7 4]
第 4 輪后:[1 2 3 4 6 5 7 8]
第 5 輪后:[1 2 3 4 5 6 7 8]
第 6 輪后:[1 2 3 4 5 6 7 8]
第 7 輪后:[1 2 3 4 5 6 7 8]
--------------------------------
排序后的數(shù)組: [1 2 3 4 5 6 7 8]

  • 升序排序。
  • 使用 i 變量表示最小元素的待放位置。
  • minPos 變量記錄最小元素的的下標(biāo)值,默認(rèn)為 i。
  • 通過變量 j 去尋找最小元素,ji + 1 的位置開始尋找。
  • 找到比 nums[minPos] 還小的元素,則將 j 的下標(biāo)值賦給 minPos
  • 一輪下來,將最小元素的位置 minPosi 的位置互換,然后繼續(xù)下一輪尋找,直到所有元素都被排序。
  • 該算法的時間復(fù)雜度為 O(N²)。

優(yōu)化算法

普通算法是尋找最小值或最大值,然后放到指定位置。優(yōu)化算法的改進點是同時尋找最小值和最大值。

import (
    "fmt"
)

func main() {
    nums := [4]int{3, 1, 4, 2}
    fmt.Println("原數(shù)組:", nums)
    fmt.Println("--------------------------------")
    SelectionSort(nums)
}

func SelectionSort(nums [4]int) {
    for left, right := 0, len(nums)-1; left <= right; {
        minPos := left
        maxPos := left
        for i := left + 1; i <= right; i++ {
            if nums[minPos] > nums[i] {
                minPos = i
            }
            if nums[maxPos] < nums[i] {
                maxPos = i
            }
        }
        nums[left], nums[minPos] = nums[minPos], nums[left]
        // 如果最大值剛好是在 left,待放最小值的位置,那么最大值就會被換走,所以需要判斷一下
        if maxPos == left {
            maxPos = minPos
        }
        nums[right], nums[maxPos] = nums[maxPos], nums[right]
        fmt.Printf("第 %d 輪后:%v\n", left+1, nums)
        left++
        right--
    }
    fmt.Println("--------------------------------")
    fmt.Println("排序后的數(shù)組:", nums)
}

執(zhí)行結(jié)果:

原數(shù)組: [8 2 3 1 6 5 7 4]
--------------------------------
第 1 輪后:[1 2 3 4 6 5 7 8]
第 2 輪后:[1 2 3 4 6 5 7 8]
第 3 輪后:[1 2 3 4 5 6 7 8]
第 4 輪后:[1 2 3 4 5 6 7 8]
--------------------------------
排序后的數(shù)組: [1 2 3 4 5 6 7 8]

  • left 變量表示待放最小值的位置,right 變量表示待放最大值的位置。minPos 記錄最小值的下標(biāo)值,maxPos 記錄最大值的下標(biāo)值,通過變量 i 去尋找最小值和最大值,尋找完畢后將它們進行交換。
  • 有一個注意的地方是,如果最大值剛好是在 left ,待放最小值的位置,那么最大值就會被換到 minPos 的位置,所以需要判斷一下,糾正下標(biāo)值。
  • 從執(zhí)行結(jié)果來看,優(yōu)化后的算法效率快了一倍,但是時間復(fù)雜度仍為 O(N²)。

小結(jié)

本文簡單介紹了什么是選擇排序,然后通過圖片的方式演示選擇排序的過程,接下來是實現(xiàn) O(N²) 時間復(fù)雜度的算法,最后優(yōu)化算法,從結(jié)果來看,優(yōu)化后的算法效率快了一倍,但是時間復(fù)雜度仍為 O(N²)。

以上就是基于Go語言實現(xiàn)選擇排序算法及優(yōu)化的詳細(xì)內(nèi)容,更多關(guān)于Go語言選擇排序算法的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解Go strconv包

    詳解Go strconv包

    Go語言中strconv包實現(xiàn)了基本數(shù)據(jù)類型和其字符串表示的相互轉(zhuǎn)換。這篇文章主要介紹了Go strconv包的相關(guān)知識,需要的朋友可以參考下
    2020-10-10
  • Golang 按行讀取文件的三種方法小結(jié)

    Golang 按行讀取文件的三種方法小結(jié)

    本文主要介紹了Golang 按行讀取文件的三種方法小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Golang CSP并發(fā)機制及使用模型

    Golang CSP并發(fā)機制及使用模型

    這篇文章主要為大家介紹了Golang CSP并發(fā)機制及使用模型,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • Golang語言如何讀取http.Request中body的內(nèi)容

    Golang語言如何讀取http.Request中body的內(nèi)容

    這篇文章主要介紹了Golang語言如何讀取http.Request中body的內(nèi)容問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Go語言atomic.Value如何不加鎖保證數(shù)據(jù)線程安全?

    Go語言atomic.Value如何不加鎖保證數(shù)據(jù)線程安全?

    這篇文章主要介紹了Go語言atomic.Value如何不加鎖保證數(shù)據(jù)線程安全詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • golang利用函數(shù)閉包實現(xiàn)簡單的中間件

    golang利用函數(shù)閉包實現(xiàn)簡單的中間件

    中間件設(shè)計模式是一種常見的軟件設(shè)計模式,它在許多編程語言和框架中被廣泛應(yīng)用,這篇文章主要為大家介紹一下golang利用函數(shù)閉包實現(xiàn)一個簡單的中間件,感興趣的可以了解下
    2023-10-10
  • Go語言中常量定義方法實例分析

    Go語言中常量定義方法實例分析

    這篇文章主要介紹了Go語言中常量定義方法,以實例形式分析了Go語言中常量的定義及使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-02-02
  • 一文帶你搞懂go中的請求超時控制

    一文帶你搞懂go中的請求超時控制

    在日常開發(fā)中,對于RPC、HTTP調(diào)用設(shè)置超時時間是非常重要的,這就需要我們設(shè)置超時控制,本文將通過相關(guān)示例為大家深入介紹一下go中的請求超時控制,希望對大家有所幫助
    2023-11-11
  • Golang并發(fā)編程之GMP模型詳解

    Golang并發(fā)編程之GMP模型詳解

    傳統(tǒng)的并發(fā)編程模型是基于線程和共享內(nèi)存的同步訪問控制的,共享數(shù)據(jù)受鎖的保護,線程將爭奪這些鎖以訪問數(shù)據(jù)。本文將介紹Go并發(fā)編程中的GMP模型,感興趣的可以了解一下
    2023-03-03
  • Golang實現(xiàn)協(xié)程超時控制的方式總結(jié)

    Golang實現(xiàn)協(xié)程超時控制的方式總結(jié)

    我們知道,go協(xié)程如果不做好處理,很容易造成內(nèi)存泄漏,所以對goroutine做超時控制,才能有效避免這種情況發(fā)生,本文為大家整理了兩個常見的Golang超時控制方法,需要的可以收藏一下
    2023-05-05

最新評論