排序---快速排序

前言

个人小记


一、代码

c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#define MAX_ARR 100000
#define swap(a,b)\
{\
    __typeof(a) __c=a;\
    a=b,b=__c;\
}
#define TEST(func ,arr,l,r)\
{\
    int n=r-l;\
    printf("test:%s\n",#func);\
    int *t=(int *)malloc(sizeof(int )*n);\
    memcpy(t,arr,n);\
    long long a=clock();\
    func(t,l,r);\
    long long b=clock();\
    if(check(t,n))printf("OK %lldms\n",(b-a)*1000/CLOCKS_PER_SEC);\
    else printf("FAIL\n");\
    free(t);\
}

int check(int *t,int n)
{
    for(int i=1;i<n;i++)
    {
        if(t[i-1]>t[i])return 0;
    }
    return 1;
}

int* init_arr(int n)
{
    int* arr=(int*)malloc(sizeof(int)*n);
    for(int i=0;i<n;i++)arr[i]=rand()%100000;
    return arr;
}

void quick_sort(int *arr,int l,int r)
{
    if(r-l<=2)
    {
        if(r-l<=1)return ;
        if(arr[l]>arr[r-1])swap(arr[l],arr[r-1]);
        return ;
    }
    int a=l,b=r-1,z=arr[a];
    while(b>a)
    {
        while(b>a&&arr[b]>z)b--;
        if(b>a)arr[a++]=arr[b];
        while(b>a&&arr[a]<z)a++;
        if(b>a)arr[b--]=arr[a];
    }
    arr[a]=z;
    quick_sort(arr,l,a);
    quick_sort(arr,a+1,r);
    return ;
}

int main()
{
    srand((unsigned)time(0));
    int *arr=init_arr(MAX_ARR);

    TEST(quick_sort,arr,0,MAX_ARR);

    free(arr);
    return 0;
}

二、测试结果

c 复制代码
test:quick_sort
OK 6ms
相关推荐
牛油果子哥q11 小时前
AVL平衡树与红黑树深度精讲对比,平衡因子、四大旋转原理、着色规则、平衡策略、性能差异与面试手撕全解
数据结构·c++·面试
汉克老师12 小时前
GESP7级C++考试语法知识(二、指数函数(3、综合练习)
c++·算法·数学建模·指数函数·gesp7级·复利
lulu121654407812 小时前
OpenRouter Fusion 多模型融合架构深度拆解:预算级模型组团打平 Fable 5,多模型协作才是 AGI 的正确打开方式?
java·人工智能·架构·ai编程·agi
雨辰AI12 小时前
生产级实测:SpringBoot3 + 达梦数据库接口从 200ms 优化至 20ms 完整调优指南
java·数据库·spring boot·后端·政务
林间码客12 小时前
04 ROC曲线与AUC:从零开始手动计算
大数据·人工智能·算法
Irissgwe12 小时前
map/set/multimap/multiset 的底层逻辑与实现
数据结构·c++·算法·二叉树·stl·c·红黑树
IronMurphy13 小时前
【算法五十八】23. 合并 K 个升序链表
数据结构·算法·链表
思茂信息13 小时前
CST软件基于液态金属开关的方向图可重构天线
服务器·算法·重构·cst·仿真软件·电磁仿真
(Charon)13 小时前
【C++ 面试高频:内存管理、RAII 和智能指针详解】
java·开发语言·word
凡人叶枫13 小时前
Effective C++ 条款39:明智而审慎地使用 private 继承
java·数据库·c++·嵌入式开发