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 }
|
请发表评论