选择排序 Go语言实现经典算法


选择排序原理

每次将未排序数组中的第一个元素与后面的元素依次比较,将最大的数字记录下来,并同未排序数组中的第一个元素交换位置。

效率

时间复杂度O(n^2), 空间复杂度O(1)
排序时间与输入无关,最佳情况,最坏情况都是如此

稳定性

选择排序是不稳定排序

Go语言实现代码

package main

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

// 选择排序
func main(){
    var numArr [10]int
    // 设置随机数种子
    rand.Seed(time.Now().UnixNano())
    // 生成一个随机数组
    for i := 0;i<10;i++{
        numArr[i]=rand.Intn(100)
    }
    fmt.Println(numArr)

    for i := 0; i < len(numArr); i++ {
        for j := i+1; j < len(numArr); j++ {
            if numArr[i] < numArr[j]{
                tmp := numArr[i]
                numArr[i] = numArr[j]
                numArr[j] = tmp
            }
        }
    }
    fmt.Println(numArr)
}

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

抢先体验

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

闪念胶囊

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

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

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

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

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

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