排序算法-快速排序法(QuickSort)

排序算法-快速排序法(QuickSort)

1、说明

快速排序法是由C.A.R.Hoare提出来的。快速排序法又称分割交换排序法,是目前公认的最佳排序法,也是使用分而治之(Divide and Conquer)的方式,会先在数据中找到一个虚拟的中间值,并按此中间值将所有打算排序的数据分为两部分。其中小于中间值的数据放在左边,而大于中间值的数据放在右边,再以同样的方式分别处理左右两边的数据,直到排序完为止。操作与分割步骤如下:

假设有n项记录,其键值为

  1. 先假设K的值为第一个键值。
  2. 从左向右找出键值,使得
  3. 从左向右找出键值,使得
  4. 如果,那么互换,并回到步骤2。
  5. 如果,那么将互相,并以为基准点分割成左、右两部分,然后针对左、右两边执行步骤1~5,直到左边键值等于右边键值为止。

2、算法分析

  1. 在最好情况和平均情况下,时间复杂度为。在最坏情况下就是每次挑中的中间值不是最大就是最小的,其时间复杂度为
  2. 快速排序法不是稳定排序法。
  3. 在最坏情况下,空间复杂度为,而在最好情况下,空间复杂度为
  4. 快速排序法是平均运行时间最快的排序法。

3、C++代码

cpp 复制代码
#include<iostream>
using namespace std;

void Print(int tempData[], int tempSize) {
	for (int i = 0; i < tempSize; i++) {
		cout << tempData[i] << "  ";
	}
	cout << endl;
}

void Quick(int tempData[], int tempLeft, int tempRight) {
	int temp;
	int leftIndex;
	int rightIndex;
	int t;
	if (tempLeft < tempRight) {
		leftIndex = tempLeft + 1;
		rightIndex = tempRight;
		while (true) {
			for (int i = tempLeft + 1; i < tempRight; i++) {
				if (tempData[i] >= tempData[tempLeft]) {
					leftIndex = i;
					break;
				}
				leftIndex++;
			}
			for (int j = tempRight; j > tempLeft + 1; j--) {
				if (tempData[j] <= tempData[tempLeft]) {
					rightIndex = j;
					break;
				}
				rightIndex--;
			}
			if (leftIndex < rightIndex) {
				temp = tempData[leftIndex];
				tempData[leftIndex] = tempData[rightIndex];
				tempData[rightIndex] = temp;
			}
			else {
				break;
			}
		}
		if (leftIndex >= rightIndex) {
			temp = tempData[tempLeft];
			tempData[tempLeft] = tempData[rightIndex];
			tempData[rightIndex] = temp;

			Quick(tempData, tempLeft, rightIndex - 1);
			Quick(tempData, rightIndex + 1, tempRight);
		}
	}
}

int main() {
	const int size = 10;
	int data[100] = { 32,5,24,55,40,81,17,48,25,71 };
	//32  5  24  55  40  81  17  48  25  71
	//32  5  24  25  40  81  17  48  55  71
	//32  5  24  25  17  81  40  48  55  71
	//17  5  24  25  32  81  40  48  55  71
	//5  17  24  25  32  81  40  48  55  71
	//5  17  25  24  32  81  40  48  55  71
	//5  17  25  24  32  71  40  48  55  81
	//5  17  25  24  32  55  40  48  71  81
	//5  17  25  24  32  48  40  55  71  81
	//5  17  25  24  32  40  48  55  71  81
	Print(data, size);
	Quick(data, 0, size - 1);
	Print(data, size);
	return 0;
}

输出结果

相关推荐
500了1 小时前
Kotlin基本知识
android·开发语言·kotlin
hong_zc1 小时前
算法【Java】—— 二叉树的深搜
java·算法
吱吱鼠叔2 小时前
MATLAB计算与建模常见函数:5.曲线拟合
算法·机器学习·matlab
嵌入式AI的盲3 小时前
数组指针和指针数组
数据结构·算法
一律清风3 小时前
QT-文件创建时间修改器
c++·qt
不知所云,3 小时前
qt cmake自定义资源目录,手动加载资源(图片, qss文件)
开发语言·qt
风清扬_jd3 小时前
Chromium 如何定义一个chrome.settingsPrivate接口给前端调用c++
前端·c++·chrome
安冬的码畜日常3 小时前
【玩转 JS 函数式编程_006】2.2 小试牛刀:用函数式编程(FP)实现事件只触发一次
开发语言·前端·javascript·函数式编程·tdd·fp·jasmine
阑梦清川3 小时前
Java继承、final/protected说明、super/this辨析
java·开发语言
PythonFun4 小时前
Python批量下载PPT模块并实现自动解压
开发语言·python·powerpoint