• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

go 语言实现简单排序

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
//冒泡
func main() {
    a := [...]int{3, 7, 8, 9, 1}
    length := len(a)
    var temp int
    for i := 0; i < length; i++ {
        for j := 0; j < length-1; j++ {
            if a[j] > a[j+1] {
                temp = a[j]
                a[j] = a[j+1]
                a[j+1] = temp
            }
        }
    }
    fmt.Printf("a:%v len(a):%v cap(a):%v\n", a, len(a), cap(a))
}
//插入排序
func main() {
    a := []int{3, 7, 8, 9, 1, 1, 10, 5}
    length := len(a)
    var temp int
    for i := 1; i < length; i++ {
        j := i
        temp = a[i] //当前参与排名的数字
        index := -1 //需要替换的index
        for {
            if j == 0 {
                if index >= 0 {
                    a[index] = temp
                    index = -1
                }
                break
            }
            if temp < a[j-1] {
                index = j - 1         //记录替换的位置
                a[index+1] = a[index] //往后移一位
            } else {
                j = 0
                continue
            }
            j--
        }
    }
    fmt.Printf("a:%v len(a):%v cap(a):%v\n", a, len(a), cap(a))
}
 
func main() {
    a := []int{3, 7, 8, 9, 1, 1, 10, 5}
    length := len(a)
    b := make([]int, len(a), cap(a))
    copy(b, a[0:1])
    var temp int
    for i := 1; i < length; i++ {
        j := i
        temp = a[i] //当前参与排名的数字
        for {
            if j > 0 && temp <= b[j-1] {
                b[j] = b[j-1] //往后移一位
                j--
            } else {
                b[j] = temp
                break
            }
        }
    }
    fmt.Printf("b:%v len(b):%v cap(b):%v\n", b, len(b), cap(b))
}

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
5.21Go秘籍:异步收割,永葆单身发布时间:2022-07-10
下一篇:
go语言将封装好的文件加入到当前工程下发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap