直接插入排序 Go语言实现经典算法


插入排序原理

插入排序又叫扑克牌排序,我个人觉得扑克牌排序(PorkerSort)要比InsertionSort这个名字更让人理解这个排序的过程。即每次将未排序数据元素比较插入到已排序的数据组中的合适的位置。

算法效率

时间复杂度O(n^2),空间复杂度O(1)
排序时间与输入有关:输入的元素个数;元素已排序的程度。
最佳情况,输入数组是已经排好序的数组,运行时间是n的线性函数; 最坏情况,输入数组是逆序,运行时间是n的二次函数。

稳定性

直接插入排序是稳定排序算法

插入排序的Go语言实现代码

package main

import "fmt"
import "time"
import "math/rand"

// 插入排序
func main(){
    rand.Seed(time.Now().UnixNano())

    numArr := make([]int,10)

    for i := 0; i < 10; i++ {
        numArr[i] = rand.Intn(100)
        // numArr = append(numArr,rand.Intn(100))
    }

    fmt.Println(numArr)

    for i := 1; i < len(numArr); i++ {

        tmp := numArr[i]
        j := i-1
        // go没有while和do while,只能用for
        // 此处不能用 numArr[i]和numArr[j]比较,因为原i位置在第一次修改后,值已改变
        for j >= 0 && tmp > numArr[j] {
            numArr[j+1] = numArr[j]
            j--
        }
        numArr[j+1] = tmp
    }
    fmt.Println(numArr)
}

本文发表于2019年12月05日 18:19
阅读 1851 讨论 0 喜欢 0

抢先体验

扫码体验
趣味小程序
文字表情生成器

闪念胶囊

你要过得好哇,这样我才能恨你啊,你要是过得不好,我都不知道该恨你还是拥抱你啊。

直抵黄龙府,与诸君痛饮尔。

那时陪伴我的人啊,你们如今在何方。

不出意外的话,我们再也不会见了,祝你前程似锦。

这世界真好,吃野东西也要留出这条命来看看

快捷链接
网站地图
提交友链
Copyright © 2016 - 2021 Cion.
All Rights Reserved.
京ICP备2021004668号-1