Go语言--冒泡排序

2020-06-19  本文已影响0人  测试探索
package main

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

func InitData(s []int) {
    //  设置种子
    rand.Seed(time.Now().UnixNano())

    for i := 0; i < len(s); i++ {
        s[i] = rand.Intn(100) //100以内的随机数

    }

    return
}

func BubbleSort(s []int) {
    n := len(s)

    for i := 0; i < n-1; i++ {
        for j := 0; j < n-1-i; j++ {
            if s[j] > s[j+1] {
                s[j], s[j+1] = s[j+1], s[j]
            }

        }
    }
}

func main() {
    n := 10
    //  创建一个切片,len为n
    s := make([] int, n)

    //   初始化数组
    InitData(s)

    //    排序前
    fmt.Println("排序前: ", s)

    //    冒泡排序
    BubbleSort(s)

//  排序后
    fmt.Println("排序后: ", s)

}

//结果
排序前:  [13 24 26 47 1 95 97 85 48 59]
排序后:  [1 13 24 26 47 48 59 85 95 97]

上一篇 下一篇

猜你喜欢

热点阅读