经典排序(待补充~
程序员文章站
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];
}
桶排序
上一篇: 指针(待补充)
下一篇: 开发中,关于会员充值的时间问题