本网站(662p.com)打包出售,且带程序代码数据,662p.com域名,程序内核采用TP框架开发,需要联系扣扣:2360248666 /wx:lianweikj
精品域名一口价出售:1y1m.com(350元) ,6b7b.com(400元) , 5k5j.com(380元) , yayj.com(1800元), jiongzhun.com(1000元) , niuzen.com(2800元) , zennei.com(5000元)
需要联系扣扣:2360248666 /wx:lianweikj
GO语言中常见的排序算法使用示例
我是陈晓 · 196浏览 · 发布于2022-04-12 +关注

这篇文章主要为大家介绍了GO语言中常见排序算法的使用示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪

快排

package main
import (
    "fmt"
    "math/rand"
    "time"
)
func main() {
    li:=[]int{1,3,5,2,4,6,9,7}
    left:=0
    right:=len(li)-1
    fmt.Println(quick_sort(li,left,right))
}
func quick_sort(li []int, left,right int) []int {
    if left<right{
        mid := paitition(li,left,right)
        quick_sort(li,left,mid-1)
        quick_sort(li,mid+1,right)
    }
    return li
}
func paitition(li []int, left,right int) int {
    r := rand.New(rand.NewSource(time.Now().UnixNano()))
    res := r.Intn(right-left+1)+left
    li[left],li[res] = li[res],li[left]
    temp:=li[left]
    for left<right {
        for left<right && li[right]>=temp{
            right-=1
        }
        li[left]=li[right]
        for left<right && li[left]<=temp{
            left+=1
        }
        li[right]=li[left]
    }
    li[left]=temp
    return left
}


冒泡 

package main
import "fmt"
func main()  {
    li:=[]int{1,3,5,2,4,6,9,7}
    fmt.Println(bubble_sort(li))
}
func bubble_sort(li[]int) []int {
    for i:=0;i<len(li)-1;i++ {
        res:=true
        for j:=0;j<len(li)-1-i;j++{
            if li[j]>li[j+1]{
                li[j],li[j+1]=li[j+1],li[j]
                res=false
            }
        }
        if res{
            return li
        }
    }
    return nil
}


选择排序 

package main
import "fmt"
func main()  {
    li:=[]int{1,3,5,2,4,6,9,7}
    fmt.Println(select_sort(li))
}
func select_sort(li[]int) []int {
    for i:=0;i<len(li);i++ {
        min_loc := i
        for j:=i+1;j<len(li);j++ {
            if li[j]<li[min_loc] {
                min_loc=j
            }
        }
        if min_loc!=i {
            li[i],li[min_loc]=li[min_loc],li[i]
        }
    }
    return li
}


插入排序 

package main
import "fmt"
func main()  {
    li:=[]int{1,3,201,5,2,100,4,6,9,7,2}
    fmt.Println(insert_sort(li))
}
func insert_sort(li[]int) []int {
    for i:=1;i<len(li); i++{
        tmp:=li[i]
        j := i-1
        for j>0 && li[j]>tmp {
            li[j+1]=li[j]
            j=j-1
        }
        li[j+1] = tmp
    }
    return li
}


希尔排序 

package main
import "fmt"
func main()  {
    li:=[]int{1,3,201,5,2,100,4,6,9,7,2}
    fmt.Println(shell_sort(li))
}
func shell_sort(li[]int) []int {
    res := len(li)/2
    for res>0 {
        for i:=res;i<len(li);i++{
            tmp := li[i]
            j := i-res
            for j>=0 && tmp <li[j]{
                li[j+res] = li[j]
                j -= res
            }
            li[j+res] = tmp
        }
        res /=2  //res = res/2
    }
    return li
}


二分法查找 

package main
import "fmt"
func main()  {
    li:=[]int{1,2,3,4,5,6,7,8}
    left:=0
    right:=len(li)-1
    value := 8
    fmt.Println(bin_search(li,value,left,right))
}
func bin_search(li[]int,value,left,right int) int {
    if left <=right{
        mid := (left+right)/2
        if li[mid] == value{
            return mid
        } else if li[mid]>value {
            return bin_search(li,value,left,mid-1)
        } else {
            return bin_search(li,value,mid+1,right)
        }
    } else {
        return 999
    }
}


GO

相关推荐

PHP实现部分字符隐藏

沙雕mars · 1325浏览 · 2019-04-28 09:47:56
Java中ArrayList和LinkedList区别

kenrry1992 · 908浏览 · 2019-05-08 21:14:54
Tomcat 下载及安装配置

manongba · 970浏览 · 2019-05-13 21:03:56
JAVA变量介绍

manongba · 962浏览 · 2019-05-13 21:05:52
什么是SpringBoot

iamitnan · 1086浏览 · 2019-05-14 22:20:36
加载中

0评论

评论
我是一名在上海一家互联网公司上班,专注技术开发工作等。
小鸟云服务器
扫码进入手机网页