go实现快速排序

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)
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值