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

核心原理:

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

优化:

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

下面函数的变量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
        }
    }
}

 

相关文章

什么是Go的接口? 接口可以说是一种类型,可以粗略的理解为他...
1、Golang指针 在介绍Golang指针隐式间接引用前,先简单说下...
1、概述 1.1&#160;Protocol buffers定义 Protocol buffe...
判断文件是否存在,需要用到"os"包中的两个函数: os.Stat(...
1、编译环境 OS :Loongnix-Server Linux release 8.3 CPU指...
1、概述 Golang是一种强类型语言,虽然在代码中经常看到i:=1...