排序算法【快速排序】

一、快速排序算法原理

直接采用实际的例子解释原理,实际的数组如下图所示。

排序算法流程如下所示

然后按照上面顺序递归下去,直到排序完成推出。

二、算法代码

cpp 复制代码
#include <stdio.h>
#include "test.h"

/* 快速排序算法 */
void quick_sort(int* arr, int begin, int len)
{
	int data;
	//如果数组只有两个元素,就没必要递归
	if ((len - begin) <= 2)
	{
		if ((len - begin) <= 1)
			return;
		if (arr[begin] > arr[begin + 1])
		{
			data = arr[begin];
			arr[begin] = arr[begin + 1];
			arr[begin + 1] = data;
		}
	}
	//选定基准值,数组中数据划分到基准值两边
	int x = begin, y = len - 1, z = arr[begin];
	while (x < y)
	{
		while ((x < y) && (arr[y] >= z)) y--;
		if(x < y) arr[x++] = arr[y];
		while ((x < y) && (arr[x] <= z)) x++;
		if (x < y) arr[y--] = arr[x];
	}
	arr[x] = z;
	quick_sort(arr, begin, x);    //这里注意选定的基准值的排序位置是对的。
	quick_sort(arr, x+1, len);
}



void main()
{
	int* arr = CreateArray(10000);
	//TEST_MY(selection_sort, arr, 10000);
	TEST_MY(quick_sort, arr, 10000);
	/*unguarded_insert_sort(arr, 0, 10000, 1);*/
	//printf("data:%d, %d, %d, %d\r\n", arr[0], arr[1], arr[2], arr[3]);
	free(arr);
	return;
}

运行结果如下所示:

相关推荐
森焱森15 分钟前
水下航行器外形分类详解
c语言·单片机·算法·架构·无人机
QuantumStack2 小时前
【C++ 真题】P1104 生日
开发语言·c++·算法
写个博客3 小时前
暑假算法日记第一天
算法
绿皮的猪猪侠3 小时前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988944 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼4 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield4 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦4 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl4 小时前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
small_wh1te_coder5 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c