C++ 快速排序算法

1、快速排序

步骤:

  1. 确定分界点 通常选 Q[L]、Q[(L+R)/2]、Q[R]
  2. 调整范围 使左边的 <=X 右边 >= X
  • 也就是 左右两边的指针,依次比较定义的分界点(X)
  • 根据比较大小调整顺序
  1. 依次递归处理左右两端

模板代码:

c++ 复制代码
// 数组  L=左边边界 R=右边边界  
void quick_sort(int q[], int L, int R) {
	//判断边界
	if (L >= R) return;

	//定义分界点
	int x = q[L];
	//定义边界 因为后面是先移动 后判断 所以将指针左右移动一格
	int left = L - 1;
	int right = R + 1;

	//这里的while条件是 左边指针和右边指针没有相遇 就继续执行
	while (left < right)
	{
		//两个指针向中间移动
		do left++;  while (q[left] < x);
		do right--; while (q[right] > x);

		if (left < right) swap(q[left], q[right]);
	}

	//对左右两边递归 再次进行分类
	quick_sort(q, L, right);
	quick_sort(q, right + 1, R);
}
相关推荐
张槊哲几秒前
C++ 进阶指南:如何丝滑地理解与实践多线程与多进程
开发语言·c++·算法
雪度娃娃8 分钟前
Effective Modern C++——型别推导
开发语言·c++
Hello eveybody26 分钟前
介绍一下背包DP(C++)
开发语言·c++·动态规划·dp·背包dp
代码中介商33 分钟前
C语言链表完全指南:从单节点到链表管理
c语言·算法·链表
charlie11451419140 分钟前
AwesomeQt:最小的Qt6系列迷你版本教程发布!
linux·c++·qt·c
小小de风呀1 小时前
de风——【从零开始学C++】(四):类和对象(下)
开发语言·c++·算法
CSCN新手听安1 小时前
【Qt】系统相关(一)内容简介,事件概念,事件的处理
开发语言·c++·qt
不想写代码的星星1 小时前
重识 std::tuple:一个被低估的编译期异构容器
开发语言·c++
aqiu1111112 小时前
[特殊字符]【算法日记 14】数论入门神题:最大公约数与最小公倍数的“乘积守恒定律”
算法
保卫大狮兄2 小时前
一文讲清:仓库管理最核心的10个公式
人工智能·算法·仓库管理