数据结构之快速排序

  快速排序的基本思想是: 通过一趟排序将待排的记录划分为独立的两部分,称为前半区和后半区,其中,前半区中记录的关键字均不大于后半区记录的关键字,然后再分别对这两部分记录继续进行快速排序,从而使整个序列有序。
  一趟快速排序的过程称为一次划分,具体做法是:附设两个位置指示变量i 和j,它们的初值分别指向序列的第一个记录和最后一个记录。设枢轴记录(通常是第一个记录)的关键字为pivot,则首先从 j 所指位置起向前搜索,找到第一个关键字小于 pivot 的记录时将该记录向前移到 i 指示的位置,然后从i 所指位置起向后搜索,找到第一个关键字大于 pivot 的记录时将该记录向后移到 j 所指位置,重复该过程直至 i 与 j 相等为止。
  【函数】快速排序过程中的划分。

int partition(int data[], int low, int high)
/*用data[low]作为枢轴元素 pivot 进行划分*/
/*使得 data[low..i-l]均不大于 pivot,data[i+l..high]均不小于 pivot*)
{
	int i, j;int pivot;
	pivot = data[low]; i=low; j=high;
	while(i <j){									/*从数组的两端交替地向中间扫描*/
		while(i <j&& data[j] >= pivot) j--;
			data[i] = data[j];						/*比枢轴元素小者往前移*/
			while (i <j && data[i] <= pivot) i++;
			data[j] = data[i];						/*比枢轴元素大者向后移*/
	}
	data[i] = pivot;
	return i;
}

  【函数】用快速排序方法对整型数组进行非递减排序。

void quickSort(int data[], int low, int high)
/*用快速排序方法对数组元素 data[low..high]作非递减排序*
{
	if(low < high){
		int loc = partition(data, low, high);		/*进行划分*/
		quicksort(data, low, loc-1):					/*对前半区进行快速排序*/
		quicksort(data, loc+1, high);					/*对后半区进行快速排序*/
	}
}/* quickSort */

  快速排序算法的时间复杂度为 O(nlog2n),在所有算法复杂度为此数量级的排序方法中,快速排序被认为是平均性能最好的一种。但是,若初始记录序列按关键字有序或基本有序时,即每次划分都是将序列划分为某一半序列的长度为0 的情况,此时快速排序的性能退化为时间复杂度是 O(n2)。快速排序是不稳定的排序方法。

相关推荐

  1. 数据结构快速排序

    2024-02-06 01:30:01       32 阅读
  2. 数据结构快速排序

    2024-02-06 01:30:01       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-06 01:30:01       14 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-06 01:30:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-06 01:30:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-06 01:30:01       18 阅读

热门阅读

  1. 网络安全简介

    2024-02-06 01:30:01       28 阅读
  2. 《微信小程序开发从入门到实战》学习九十九

    2024-02-06 01:30:01       34 阅读
  3. C# Avalonia 11.0.6 绘图

    2024-02-06 01:30:01       29 阅读
  4. SQL的函数类型

    2024-02-06 01:30:01       35 阅读
  5. 【工具】使用asciidoctor-pdf将adoc文件转换成pdf

    2024-02-06 01:30:01       31 阅读
  6. linux使用docker安装rancher

    2024-02-06 01:30:01       27 阅读
  7. PyTorch的 torch.unsqueeze() 和 torch.squeeze()方法详解

    2024-02-06 01:30:01       23 阅读