1.快速排序
思想:分治算法
三步骤:1.找一个分界值x;
2.将小于等于x的放在左边,将大于等于x的放在右边;
3。递归左右两边;
#include<iostream> using namespace std; const int N=1e5+10; void quick_sort(int q[],int l,int r) { if(l>=r){ return; } int x=q[(l+r)/2],i=l-1,j=r+1; while(i<j){ do i++;while(q[i]<x); do j--;while (q[j]>x); if(i<j) swap(q[i],q[j]); } quick_sort(q,l,j); quick_sort(q,j+1,r); } int main(){ int n; cin>>n; int q[N]; for(int i=0;i<n;i++) cin>>q[i]; quick_sort(q,0,n-1); for(int i=0;i<n;i++) printf("%d ",q[i]); return 0; }
标签:sort,int,等于,quick,排序,快速 From: https://www.cnblogs.com/aixin52129211/p/17304093.html