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

快速排序和二分查找(Go)

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

import (
"fmt"
"sync"
)

var waitGroup sync.WaitGroup

func main() {

data := []int{2, 3, 5, 1, 4, 5, 2, 13, 51, 9, 10, 15, 17, 6, 21, 33, 44, 77, 22}
fmt.Println(data)

waitGroup.Add(1)
go performQuickSort(data)

waitGroup.Wait()

var index = binarySearch(data, 4)
fmt.Println(index)
}

func performQuickSort(data []int) {
defer waitGroup.Done()
quickSort(data, 0, len(data)-1)
fmt.Println(data)
}

func quickSort(data []int, left int, right int) {
index := partition(data, left, right)

if left < index-1 {
quickSort(data, left, index-1)
}

if right > index {
quickSort(data, index, right)
}
}

func partition(data []int, left int, right int) int {
i := left
j := right

pivot := data[left+(right-left)/2]

for i <= j {

for data[i] < pivot {
i++
}

for data[j] > pivot {
j--
}

if i <= j {
temp := data[i]
data[i] = data[j]
data[j] = temp
i++
j--
}
}

return i;
}

func binarySearch(data []int, target int) int {

left := 0;
right := len(data) - 1

for left <= right {
mid := left + (right-left)/2
if data[mid] < target {
left = mid + 1
}

if data[mid] >= target {
right = mid - 1
}
}

return left
}

鲜花

握手

雷人

路过

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

请发表评论

全部评论

专题导读
上一篇:
go切片排序发布时间:2022-07-10
下一篇:
一个 GO 语言性能问题的发现和解决发布时间: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