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

本文展示了一个使用Go语言实现的快速排序算法和二分查找算法的示例。通过并发执行快速排序,对一个整数数组进行排序,并使用二分查找在排序后的数组中查找特定元素的位置。
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
}

转载于:https://www.cnblogs.com/feicheninfo/p/9283350.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值