日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

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

作者:宇宙之一粟 ? 更新時間: 2022-10-23 編程語言

插入排序

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

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

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

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

動畫演示

假設(shè)我們需要從小到大進行排序,動畫演示如下:

Go 代碼實現(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
    }
}

運行結(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)簡單,理解也較容易,數(shù)據(jù)量較少時效率高,算法的實際運行效率優(yōu)于選擇排序和冒泡排序。

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

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

原文鏈接:https://juejin.cn/post/7044021081933348894

欄目分類
最近更新