快速排序
排序在各種場合經常被用到。
快速排序是十分常用的高效率的算法。
其思想是:先選一個“標尺”,
用它把整個隊列過一遍篩子,
以保證:其左邊的元素都不大於它,其右邊的元素都不小於它。
這樣,排序問題就被分割為兩個子區間。
再分別對子區間排序就可以了。
#include<iostream> #include<stdio.h> #include<algorithm> using namespace std; typedef long long LL; const int maxn=1e4+5; int a[maxn]; int N; LL ans=0; int Find(int l,int r) { int x=a[l]; int i=l; int j=r+1; while(1) { while(a[++i]<x&&i<=r) ;//找到第一個大於x的數 while(a[--j]>x&&j>=l) ;//找到第一個小於x的數 if(i>=j) break; ans++; swap(a[i],a[j]); } if(j>l) { ans++; swap(a[l],a[j]); } return j; } void quicksort(int l,int r) { //int p=l; if(l<r) { int p=Find(l,r); quicksort(l,p-1); quicksort(p+1,r); } return ; } int main() { scanf("%d",&N); for(int i=0;i<N;i++) scanf("%d",&a[i]); quicksort(0,N-1); printf("%lld\n",ans); return 0; }
int split(int a[],int low,int high) { //以最左邊的元素為基准 int i=low; int x=a[low]; for(int j=low+1;j<=high;j++) //遍歷一遍 { //將小於x的元素往前挪 if(a[j]<=x) // { i++; swap(a[i],a[j]); } } //此時在low+1到i位置所有元素都小於等於low所在的位置 i+1到high都大於low所在的位置 swap(a[i],a[low]);//將low換到期待的位置 return i; } void Quick_sort(int a[],int low,int high) { if(low<high) { int i=split(a,low,high); Quick_sort(a,low,i-1); Quick_sort(a,i+1,high); } }