package main
import "fmt"
func swap(arr []int, i, j int) {
arr[i], arr[j] = arr[j], arr[i]
}
func partition(arr []int, left, right, key int) []int { // 划分
less := left - 1 // 小于区
more := right + 1 // 大于区
index := left // 下标
for index < more {
if arr[index] < key { // 小于划分值,就放到小于区
swap(arr, less+1, index)
less++ // 扩大小于区
index++ // 比较下一个值
} else if arr[index] > key { // 大于划分值,就放到大于区
swap(arr, more-1, index)
more-- // 扩大大于区;索引位置不变(因为当前值已经改变,需要再次比较)
} else {
index++ // 相同时,继续比较下一个
}
}
// 返回等于区的位置
return []int{less + 1, more - 1}
}
func quickSort(arr []int, left, right int) {
if arr == nil || len(arr) < 2 {
return
}
if left < right {
part := partition(arr, left, right, arr[right]) //将数组最右边的值作为划分值
quickSort(arr, left, part[0]-1)
quickSort(arr, part[1]+1, right)
}
}
func main() {
arr := []int{3, 9, 1, 4, 7}
fmt.Println("排序前:", arr)
quickSort(arr, 0, len(arr)-1)
fmt.Println("排序后:", arr)
}
go实现快速排序
最新推荐文章于 2025-02-15 08:00:00 发布