首页 > 编程语言 > 详细

基础算法

时间:2021-06-06 13:14:36      阅读:15      评论:0      收藏:0      [点我收藏+]

排序

快速排序

#include <bits/stdc++.h>
using namespace std;
const int N = 1e6 + 10;
int n;
int q[N];
void quick_sort(int q[], int l, int r){
    if(l==r) return;
    int i = l - 1, j = r + 1, x = q[l+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()
{
    scanf("%d",&n);
	for(int i=0;i<n;i++) scanf("%d",&q[i]);
	quick_sort(q, 0, n-1);
	for(int i=0;i<n;i++) printf("%d ",q[i]);
	
    return 0;
}

基础算法

原文:https://www.cnblogs.com/zheblog/p/14854792.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!