go实现随机快速排序

本文详细介绍了如何使用Go语言实现随机化快速排序算法,包括排序原理、代码实现及性能分析,帮助读者理解并掌握这一高效排序技巧。

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

package main

import (
	"fmt"
	"math/rand"
	"time"
)

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 randInt(left, right int) int { //生成随机数
	rand.Seed(time.Now().UnixNano())
	// 生成[left, right]闭区间内的随机数
	return rand.Intn(right-left+1) + left 
}

func RandomQuickSort(arr []int, left, right int) {
	if arr == nil || len(arr) < 2 {
		return
	}
	if left < right {
		//选取随机数
		key := randInt(left, right) //随机选择一个数组下标
		fmt.Println("随机数key = ", key)
		key = arr[key] //取出随机划分值
		fmt.Println("数组值key = ", key)
		part := partition(arr, left, right, key) //随机选择一个数组中的数作为划分值
		RandomQuickSort(arr, left, part[0]-1)
		RandomQuickSort(arr, part[1]+1, right)
	}
}

func main() {
	arr := []int{3, 1, 2, 23, 8}	
	fmt.Println("排序前:", arr)
	RandomQuickSort(arr, 0, len(arr)-1)	
	fmt.Println("排序后:", arr)
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值