快速排序算法

快速排序思想:每次确定一个结点的最终位置,然后再将数组按这个结点位置左右划分为两个区间依次继续确定新结点位置。

平均时间复杂度,但当原数组基本有序的情况下复杂度达到

int partition(int a[], int low, int high){
	int pivot=a[low];
	//low=high就是两个指针同时指向一个空结点 
	while(low<high){
		//移动是high和low交叉移动,两个while循环分布代表两个指针移动,保证非空指针移动 
		while(high>low && a[high]>=pivotpos)high--;
		a[low]=a[high];
		while(high>low && a[low]<=pivotpos)low++;
		a[high]=a[low];
	}
	//最后low=high=pivot 
	a[low]=pivot;
	return low;
}
void QuicSort(int a[], int low, int high) {
	//low=high代表只有一个点,不需要排序了 
	if(low<high){
		//先找到中心枢纽点的位置,再根据这个位置左右继续划分排序; 
		int pivotpos=partition(a, low, high);
		QuicSort(a, low, pivotpos-1);
		QuicSort(a, pivotpos+1, high);	
	}
}
相关推荐
IT猿手2 分钟前
2025高维多目标优化:基于导航变量的多目标粒子群优化算法(NMOPSO)的无人机三维路径规划,MATLAB代码
开发语言·人工智能·算法·机器学习·matlab·无人机·cocos2d
阿乾之铭17 分钟前
动态规划算法
算法·动态规划
菠菠萝宝19 分钟前
【代码随想录】第九章-动态规划(上)
算法·动态规划·01背包·完全背包·多重背包·上楼梯
DTDanteDong20 分钟前
从头再来!社招找工作——算法题复习九:动态规划
算法·动态规划
Coco_926425 分钟前
Hot100 动态规划
算法·动态规划
卑微的小鬼33 分钟前
golang的var ,make ,new, := 的区别
算法
MZWeiei1 小时前
PTA:有序顺序表的插入
数据结构
01_1 小时前
力扣hot100 ——和为k的子数组 前后缀和(积)各种情况总结
数据结构·算法·leetcode·前后缀和(积)计算
刀客1231 小时前
数据结构与算法再探(七)查找-排序
数据结构
一只码代码的章鱼1 小时前
数据结构与算法-搜索-双向搜索 和 A*算法(字串变换,八数码,第k短路)
算法