golang 冒泡排序实现
排序,顾名思义,就是把一坨数字按照某种特定的顺序排列好了,比如从小到大又或者从大到小。
冒泡排序,冒泡嘛,形象一点儿,就是一个个泡泡往上涌,然后和“相邻的泡泡”比试,最后最小的泡泡浮到了水面上。既然是想要让小的从底部都涌到上面,那么为何不尝试一下最后往前呢?
package main import( "fmt" ) //冒泡排序常规排序 /*func Bubblesort(arr *[5]int) { fmt.Println("排序前arr=",(*arr)) temp:=0 for i:=0; i<len(*arr)-1;i++{ for j:=0;j<len(*arr)-1-i;j++{ if(*arr)[j] > (*arr)[j+1]{ temp = (*arr)[j] (*arr)[j] = (*arr)[j+1] (*arr)[j+1] = temp } } } fmt.Println("排序后arr=",(*arr)) }*/ //冒泡排序 比上者排序更有优势,特殊情况arr:=[5]int{7,10,20,35,98}这种情况就无需所有再次遍历 func Bubblesort(arr *[5]int) { fmt.Println("排序前arr=",(*arr)) temp:=0 swap:=true for i:=0; i<len(*arr)&& swap==true;i++{ swap=false for j:=len(*arr)-1; j > i; j--{ if(*arr)[j] < (*arr)[j-1]{ temp = (*arr)[j] (*arr)[j] = (*arr)[j-1] (*arr)[j-1] = temp swap = true } } } fmt.Println("排序后arr=",(*arr)) } func main() { arr:=[5]int{20,98,10,35,7} Bubblesort(&arr) }