go 语言实现快速排序
创始人
2025-01-07 14:32:46
0

快速排序 - go

  • 一、思路
  • 二、步骤及图解
  • 三、代码实现
  • 四、复杂度分析

一、思路

  快速排序是一种分治策略的排序算法,关键过程是对数组进行划分。选择一个基准值(pivot element),围绕着这个基准值划分子数组,对子数组递归调用快速排序,直到数组有序。

二、步骤及图解

1、选取基准元素。将最后一个元素(随机值、三数中值) 作为基准值 pivot。
2、划分子数组。遍历数组,将小于基准值的元素交换到左边,大于基准值的元素交换到右边,将基准值交换到正确的位置,并返回其索引作为分区点。经过这一步骤之后,数组被划分成小于和大于基准值的2个子数组。
3、递归调用。递归地对这2个子数组进行快速排序,直到整个数组有序。

  • 一次快速排序的过程

在这里插入图片描述

  • 快速排序全过程

在这里插入图片描述

  • 数组变化

在这里插入图片描述

三、代码实现

package main  import "fmt"  func main() { 	arr := []int{10, 8, 3, 9, 7, 1, 2, 5} 	quickSort(arr, 0, len(arr)-1) 	fmt.Println("Sorted array:", arr) // Sorted array: [1 2 3 5 7 8 9 10] }  // left,right分别为数组的最左、最右下标 func quickSort(arr []int, left, right int) { 	if left >= right { // 递归截止条件 		return 	} 	pivot := partition(arr, left, right) 	quickSort(arr, left, pivot-1) 	quickSort(arr, pivot+1, right) }  // 分区函数 func partition(arr []int, left, right int) int { 	pivot := arr[right] // 选择数组的最后一个元素作为基准值 	i := left           // 数组最左元素的下标 	for j := left; j < right; j++ { 		if arr[j] < pivot { // 将小于基准值的元素交换到左边 			arr[i], arr[j] = arr[j], arr[i] 			i++ 		} 	} 	// 处理基准值 	arr[i], arr[right] = arr[right], arr[i] 	return i }  // 空间复杂度:O(1), 在分区时使用原地交换的方式 

四、复杂度分析

  • 时间复杂度:O(n log n)
      快速排序的时间复杂度可以通过递归树来分析。在每一层中,我们选择一个主元素并将数组划分为两个子数组,时间复杂度为O(n)。如果我们将递归树表示为二叉树,则总共有 log n 层,并且每层的时间复杂度为 O(n),因此整个算法的时间复杂度为 O(n log n)。

以下情况快速排序的时间复杂度将退化为 O(n^2):
  1、数组已经有序。在待排序数组已经有序的情况下,每次划分只能减少一个元素,时间复杂度将退化为 O(n^2)。
  2、基准值有问题。选择的基准值不能把数组分区成均衡的两部分,基准值都是最小或最大的元素,导致每次分区后,一个子数组为空,而另一个子数组包含剩余的所有元素,时间复杂度将退化为O(n^2)。

  • 空间复杂度:O(log n)
      快速排序的空间复杂度主要由递归调用栈决定。在最好的情况下(即每次分区都非常平衡),递归深度为 log n,因此空间复杂度为 O(log n)。

  在最坏的情况下(即每次分区都极度不平衡),递归深度可以达到 n,空间复杂度将退化为 O(n)。

  快速排序是不稳定的排序算法,因为在排序过程中会涉及到交换操作,可能导致相同元素的相对顺序发生变化。

  然而,有时候也可以通过一些技巧使得快排变成稳定排序。例如,在选择主元素时,可以选择第一个或最后一个元素,这样就可以避免在分区过程中出现相同元素的前后位置发生变化的情况。

相关内容

热门资讯

微乐小程序真的有挂!微乐山西小... 微乐小程序真的有挂!微乐山西小程序破解器(开挂)攻略-原来科普是真的挂该软件可以轻松地帮助玩家将外卦...
透视教你!微乐小程序黑科技(外... 透视教你!微乐小程序黑科技(外挂),微乐南昌辅助神器,教程总结(真实有挂)-哔哩哔哩1、超多福利:超...
事发当天!微乐小程序黑科技,微... 事发当天!微乐小程序黑科技,微乐自建房脚本免费入口(作弊器)积累教程(总是真的是有挂)一、游戏安装教...
微信小程序黑科技免费!微信小程... 微信小程序黑科技免费!微信小程序游戏破解器(开挂)教程-切实科普真的有挂微信小程序黑科技免费!微信小...
值得注意的是!微乐小程序免费黑... 值得注意的是!微乐小程序免费黑科技,微乐家乡app下载(作弊器)操作教程(真是有挂)1)有没有挂:进...
透视辅助!微乐小程序黑科技(外... 透视辅助!微乐小程序黑科技(外挂),微乐云南小程序辅助器,教程方针(有挂透明挂)-哔哩哔哩1、不需要...
微乐小程序透视挂!微信小程序游... 微乐小程序透视挂!微信小程序游戏辅助器(开挂)挂-一直揭露真的是有挂1)免费钻石:进一步探索免费脚本...
微乐小程序真的有挂!微乐小程序... 微乐小程序真的有挂!微乐小程序免费脚本(开挂)教程-真是曝光是有挂1、在插件功能辅助器技巧中,中转单...
微乐小程序黑科技!微乐自建房免... 微乐小程序黑科技!微乐自建房免费黑科技下载苹果(开挂)插件-总是了解存在有挂1、公共底牌简单,透视插...
微乐小程序黑科技免费!微信小程... 微乐小程序黑科技免费!微信小程序有挂吗辅助(开挂)神器-真是详细真的是有挂1、模拟器是什么优化,俱乐...