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

[Go]Golang练习项目-GO实现冒泡排序以及优化算法

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

核心原理:

比较相邻的两个元素,较大的一个交换移动到右边

优化:

已经排好序的元素不再进行比较,减少比较次数

下面函数的变量flag 用于判断后续元素有无发生交换,没有发生交换的直接停止遍历

变量lastSwapIndex ,记录最后一次发生交换的位置,后续元素不再进行比较

//冒泡排序
func BubbleSort(arr *[]int){
    flag:=true
    lastSwapIndex:=0
    for i:=0;i<len(*arr)-1;i++{
        sortBorder:=len(*arr)-1-i
        for j:=0;j<sortBorder;j++{
            if (*arr)[j]>(*arr)[j+1]{
                temp:=(*arr)[j]
                (*arr)[j]=(*arr)[j+1]
                (*arr)[j+1]=temp
                flag=false
                lastSwapIndex=j
            }
        }
        sortBorder=lastSwapIndex
        if flag{
            break
        }
    }
}

 


鲜花

握手

雷人

路过

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

请发表评论

全部评论

专题导读
上一篇:
[Go]理解切片slice扩容发布时间:2022-07-10
下一篇:
window.history.go(-1)和window.location.go(-1)的区别发布时间: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