AcWing 785. 快速排序

Posted MangataTS

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AcWing 785. 快速排序相关的知识,希望对你有一定的参考价值。

题目连接

https://www.acwing.com/problem/content/787/

思路

找一个分界点,然后坐标左边都小于他,右边都大于他,体现分治的思想
我们有一个l和r指针,都往中间走,然后左边遇到大于我们选中的x值就停下来,右边就遇到小于我们选择的x值就停下来,然后交换两数,然后重复这个过程,知道两个指针相遇就完成了我们的划分,即x左边的都小于等于x,x右边的都大于等于x

#include<bits/stdc++.h>
using namespace std;

const int N = 1e6+10;
int a[N];
void mysort(int a[],int l,int r)
	if(l >= r) return;
	int x = a[l+r>>1],i=l-1,j=r+1;
	while(i < j) 
	    while(a[++i] < x);
	    while(a[--j] > x);
		if(i < j) swap(a[i],a[j]);
	
	mysort(a,l,j);
	mysort(a,j+1,r);




int main()

	int n;
	scanf("%d",&n);
	for (int i = 0; i < n; i ++ )
		scanf("%d",&a[i]);
	
	mysort(a,0,n-1);
	for (int i = 0; i < n; i ++ )
		printf("%d ",a[i]);
	
	
	return 0;

以上是关于AcWing 785. 快速排序的主要内容,如果未能解决你的问题,请参考以下文章

Acwing785.快速排序

AcWing 785. 快速排序

Acwing 785. 快速排序/AcWing 786. 第k个数

算法AcWing 785. 快速排序

AcWing基础算法课Level-2 第一讲 基础算法

D5-AcWing-8002816801803+复习785-799