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

Go語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之插入排序示例詳解

 更新時(shí)間:2022年08月26日 15:11:42   作者:宇宙之一粟  
這篇文章主要為大家介紹了Go語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之插入排序示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

插入排序

插入排序,英文名(insertion sort)是一種簡(jiǎn)單且有效的比較排序算法。

思想: 在每次迭代過(guò)程中算法隨機(jī)地從輸入序列中移除一個(gè)元素,并將改元素插入待排序序列的正確位置。重復(fù)該過(guò)程,直到所有輸入元素都被選擇一次,排序結(jié)束。

插入排序有點(diǎn)像小時(shí)候我們抓撲克牌的方式,如果抓起一張牌,我們放在手里;抓起第二張的時(shí)候,會(huì)跟手里的第一張牌進(jìn)行比較,比手里的第一張牌小放在左邊,否則,放在右邊。

因此,對(duì)所有的牌重復(fù)這樣的操作,所以每一次都是插入最正確的排序順序,直到牌抓完為止。

動(dòng)畫(huà)演示

假設(shè)我們需要從小到大進(jìn)行排序,動(dòng)畫(huà)演示如下:

Go 代碼實(shí)現(xiàn)

package main
import "fmt"
func main() {
    arrays := []int{6, 2, 5, 8, 9, 3, 1}
    length := len(arrays)
    insertionSort(arrays, length)
    for i := 0; i < length; i++ {
        fmt.Printf("%d ", arrays[i])
    }
}
func insertionSort(unsorted []int, length int) {
    for i := 0; i < length; i++ {
        var insertElement = unsorted[i]
        var insertPosition = i
        for j := insertPosition - 1; j >= 0; j-- {
            if insertElement < unsorted[j] {
                unsorted[j+1] = unsorted[j]
                insertPosition--
            }
        }
        unsorted[insertPosition] = insertElement
    }
}

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

[Running] go run "e:\Coding Workspaces\LearningGoTheEasiestWay\Go 數(shù)據(jù)結(jié)構(gòu)\main.go"
1 2 3 5 6 8 9

總結(jié)

插入排序?qū)崿F(xiàn)簡(jiǎn)單,理解也較容易,數(shù)據(jù)量較少時(shí)效率高,算法的實(shí)際運(yùn)行效率優(yōu)于選擇排序和冒泡排序。

空間復(fù)雜度: 空間復(fù)雜度為 O(1),即不輸入借助其他的輔助空間。

穩(wěn)定性: 插入排序是穩(wěn)定的排序算法,在鍵值相同時(shí)它能夠保持輸入數(shù)據(jù)的原有次序。

以上就是Go語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之插入排序示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Go 數(shù)據(jù)結(jié)構(gòu)插入排序的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • golang判斷文本文件是否是BOM格式的方法詳解

    golang判斷文本文件是否是BOM格式的方法詳解

    在Go語(yǔ)言中,我們可以通過(guò)讀取文本文件的前幾個(gè)字節(jié)來(lái)識(shí)別它是否是BOM格式的文件,BOM(Byte Order Mark)是UTF編碼標(biāo)準(zhǔn)中的一部分,用于標(biāo)示文本文件的編碼順序,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • Go 自定義error錯(cuò)誤的處理方法

    Go 自定義error錯(cuò)誤的處理方法

    這篇文章主要介紹了Go 自定義error錯(cuò)誤的處理方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • golang實(shí)現(xiàn)各種情況的get請(qǐng)求操作

    golang實(shí)現(xiàn)各種情況的get請(qǐng)求操作

    這篇文章主要介紹了golang實(shí)現(xiàn)各種情況的get請(qǐng)求操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • Go操作mongodb數(shù)據(jù)庫(kù)方法示例

    Go操作mongodb數(shù)據(jù)庫(kù)方法示例

    這篇文章主要為大家介紹了Go操作mongodb數(shù)據(jù)庫(kù)方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • golang HTTP 服務(wù)器 處理 日志/Stream流的操作

    golang HTTP 服務(wù)器 處理 日志/Stream流的操作

    這篇文章主要介紹了golang HTTP 服務(wù)器 處理 日志/Stream流的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • Go語(yǔ)言中常見(jiàn)的坑以及高性能編程技巧分享

    Go語(yǔ)言中常見(jiàn)的坑以及高性能編程技巧分享

    代碼的穩(wěn)健性、高性能、可讀性是我們每一位coder必須去追求的目標(biāo),本文結(jié)合Go語(yǔ)言的特性做了相關(guān)總結(jié),感興趣的小伙伴可以了解一下
    2023-06-06
  • Go語(yǔ)言?xún)?nèi)置包的使用

    Go語(yǔ)言?xún)?nèi)置包的使用

    本文主要介紹了Go語(yǔ)言?xún)?nèi)置包的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • GoFrame代碼優(yōu)化gconv類(lèi)型轉(zhuǎn)換避免重復(fù)定義map

    GoFrame代碼優(yōu)化gconv類(lèi)型轉(zhuǎn)換避免重復(fù)定義map

    這篇文章主要為大家介紹了GoFrame代碼優(yōu)化gconv類(lèi)型轉(zhuǎn)換避免重復(fù)定義map示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • Go語(yǔ)言開(kāi)發(fā)k8s之ConfigMap操作解析

    Go語(yǔ)言開(kāi)發(fā)k8s之ConfigMap操作解析

    這篇文章主要為大家介紹了Go語(yǔ)言開(kāi)發(fā)k8s之ConfigMap操作示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • 使用Go+GoQuery庫(kù)實(shí)現(xiàn)頭條新聞采集

    使用Go+GoQuery庫(kù)實(shí)現(xiàn)頭條新聞采集

    在本文中,我們將介紹如何使用Go語(yǔ)言和GoQuery庫(kù)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的爬蟲(chóng)程序,用于抓取頭條新聞的網(wǎng)頁(yè)內(nèi)容,我們還將使用爬蟲(chóng)代理服務(wù),提高爬蟲(chóng)程序的性能和安全性,我們將使用多線程技術(shù),提高采集效率,最后,我們將展示爬蟲(chóng)程序的運(yùn)行結(jié)果和代碼,需要的朋友可以參考下
    2023-10-10

最新評(píng)論