golang-quick-sort

本文介绍了一种使用Go语言实现的递归版快速排序算法。通过定义一个包含10个整数的数组,演示了如何进行快速排序的过程,并详细展示了排序过程中数组状态的变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package main

import (
	"fmt"
)

func main() {
	var arr = []int{6, 5, 5, 3, 1, 8, 7, 2, 4, 9}
	start := 0
	end := len(arr) - 1
	fmt.Println(arr)
	QuickSortRecursive(arr, start, end)
}

func QuickSortRecursive(arr []int, start int, end int) {
	if start >= end {
		return
	}
	k := arr[end]
	left := start
	right := end - 1
	for left < right {
		for arr[left] < k && left < right {
			left++
		}
		for arr[right] >= k && left < right {
			right--
		}
		arr[left], arr[right] = arr[right], arr[left]
		fmt.Println(arr)
	}
	if arr[left] < arr[end] {
		left++
	}
	arr[left], arr[end] = k, arr[left]
	fmt.Println(arr)
	QuickSortRecursive(arr, start, left-1)
	QuickSortRecursive(arr, left+1, end)
}
递归版快速排序
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值