今天小编给大家分享一下Go语言中常见的排序算法怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。快排package&nb
今天小编给大家分享一下Go语言中常见的排序算法怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
package mainimport ("fmt""math/rand""time")func main() {li:=[]int{1,3,5,2,4,6,9,7}left:=0right:=len(li)-1fmt.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)+leftli[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]=tempreturn left}
package mainimport "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:=truefor 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 mainimport "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 := ifor 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 mainimport "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-1for j>0 && li[j]>tmp {li[j+1]=li[j]j=j-1}li[j+1] = tmp}return li}
package mainimport "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)/2for res>0 {for i:=res;i<len(li);i++{tmp := li[i]j := i-resfor j>=0 && tmp <li[j]{li[j+res] = li[j]j -= res}li[j+res] = tmp}res /=2 //res = res/2}return li}
package mainimport "fmt"func main() {li:=[]int{1,2,3,4,5,6,7,8}left:=0right:=len(li)-1value := 8fmt.Println(bin_search(li,value,left,right))}func bin_search(li[]int,value,left,right int) int {if left <=right{mid := (left+right)/2if 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语言中常见的排序算法怎么使用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网精选频道。
--结束END--
本文标题: GO语言中常见的排序算法怎么使用
本文链接: https://lsjlt.com/news/326856.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0