欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

经典排序(待补充~

程序员文章站 2022-05-12 16:34:45
...

快排

void qsort(int a[],int l,int r){
    if(l == r) return;

    int i = l - 1,j = r + 1,m = a[l + r >> 1];
    while(i < j){
        do i ++;while(a[i] < m);
        do j --;while(a[j] > m);
        if(i < j) swap(a[i],a[j]);
    }

    qsort(a, l, j);
    qsort(a, j + 1, r);
}

归并排序

int a[N],c[N];
void merge_sort(int l,int r){
    if(l >= r) return;
    int mid = l + r >> 1;
    merge_sort(l, mid);
    merge_sort(mid + 1, r);
    int i = l,k = l,j = mid + 1;
    while(i <= mid && j <= r){
        if(a[i] <= a[j]) c[k ++] = a[i ++];
        else c[k ++] = a[j ++];
    }
    while(i <= mid) c[k ++] = a[i ++];
    while(j <= r) c[k ++] = a[j ++];

    for(int m = l;m <= r;m ++) a[m] = c[m];
}

桶排序

相关标签: ACM模板 算法