【算法】排序——快速排序
创始人
2024-03-19 04:14:48
0

快速排序

(1)快速排序是对冒泡排序的一种改进。基本思想是,通过一趟排序将待记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序。利用分治法容易实现快速排序的算法设计

(2)选取第一个元素的关键字作为界值讨论快速排序的算法

① 设置两个指针left和right,分别从表的两端向中间移动,将界值元素放入一个暂存单元

② 将指针right对序列自右向左扫描,直到找到一个关键字小于界值的元素,将该元素移至left指针所在位置

③ 将指针left对序列自左向右扫描,直到找到一个关键字大于或等于界值的元素,将其放入right指针所指位置。

④ 重复步骤②和③,直到指针left和right相遇,此时,指针所在位置的左边元素关键字值均小于界值,右边所有元素关键字值均大于等于界值。将界值元素放入指针相遇位置

⑤ 对产生的两个子序列,再进行如上所述的划分,直到所有子序列中只有一个元素为止。

(3)快速排序算法 

int Partition(int list[],int low,int high){
    int pivotkey;
    list[0]=list[low];
    pivotkey=list[low];
    while(low
        while(low=pivotkey){
            --high;
        }
        list[low]=list[high];
        while(low
            ++low;
        }
        list[high]=list[low];
    }
    list[low]=list[0];
    return low;
}
void QSort(int list[],int low,int high){
    int pivotloc,i,pivotkey;
    pivotkey=list[low];
    if(low
        pivotloc=Partition(list,low,high);
        QSort(list,low,pivotloc-1);
        QSort(list,pivotloc+1,high);
    }

(4)完整程序

#include
#define N 20
int list[N+1];
void insertSort(int list[],int n){
    int i,j;
    for(i=2;i<=n;i++){
        list[0]=list[i];
        j=i-1;
        while(j>0&&list[0]
            list[j+1]=list[j];
            j--;
        }
        list[j+1]=list[0];
    }
}
void bubbleSort(int list[],int n){
    int i=1,j,t,flag=1;
    for(i=1;i
        flag=0;
        for(j=1;j<=n-1;j++){
            if(list[j]>list[j+1]){
                t=list[j];
                list[j]=list[j+1];
                list[j+1]=t;
                flag=1;
            }
        }
    }
}
void SelectSort(int list[],int n){
    int i,j,k,temp;
    for(i=1;i<=n-1;++i){
        k=i;
        for(j=i+1;j<=n;j++){
            if(list[j]             k=j;
        }
        if(i!=k){
            temp=list[i];
            list[i]=list[k];
            list[k]=temp;
        }
    }

void Shellinsert(int list[],int dk,int n){
    int i,j;
    for(i=dk+1;i<=n;i++){
        if(list[i]
            list[0]=list[i];
            for(j=i-dk;j>0&&list[0]
                list[j+dk]=list[j];
            }
            list[j+dk]=list[0];
        }
    }
}
void ShellSort(int list[],int dlta[],int t,int n){
    int i,k;
    for(k=0;k
        Shellinsert(list,dlta[k],n);
    }
}
int Partition(int list[],int low,int high){
    int pivotkey;
    list[0]=list[low];
    pivotkey=list[low];
    while(low
        while(low=pivotkey){
            --high;
        }
        list[low]=list[high];
        while(low
            ++low;
        }
        list[high]=list[low];
    }
    list[low]=list[0];
    return low;
}
void QSort(int list[],int low,int high){
    int pivotloc,i,pivotkey;
    pivotkey=list[low];
    if(low
        pivotloc=Partition(list,low,high);
        QSort(list,low,pivotloc-1);
        QSort(list,pivotloc+1,high);
    }
}
int main(){
    int i,n;
    scanf("%d",&n);
    for(i=1;i<=n;i++){
        scanf("%d",&list[i]);
    }
    //insertSort(list,n);
    //bubbleSort(list,n);
    //SelectSort(list,n);
    int dlta[3]={5,3,1};
    //ShellSort(list,dlta,3,n);
    QSort(list,1,n);
    for(i=1;i<=n;i++){
        printf("%d ",list[i]);
    } 
    return 0;

 

相关内容

热门资讯

恒瑞医药发生7笔大宗交易 合计... 恒瑞医药7月28日大宗交易平台共发生7笔成交,合计成交量786.00万股,成交金额4.68亿元。成交...
公司动态|中铁信托家族信托办公... 近日,中铁信托家族信托办公室携手光大银行重庆分行私行部,开展了保险金信托交流活动。活动中,中铁信托家...
四川2025年窗口行业文明新风... 四川在线记者 张蒙 视频/图片 向宇7月28日,“文明润蜀乡 服务惠万家”——四川省2025年窗口行...
平罗:精准预警 高效处置 多部...   7月23日至24日,宁夏回族自治区石嘴山市平罗县出现强降雨,最大降水量达96.6毫米。平罗县气象...
董璇透露与张维伊相处曾陷困境 (来源:河北长城网)转自:河北长城网 【#董璇透露与张维...
江苏舜天(600287.SH)... 江苏舜天(600287.SH)发布公告,为加快推动海外产能布局,实现供应链运营的转型升级,公司及公司...
新天绿色能源(00956.HK... 格隆汇7月28日丨新天绿色能源(00956.HK)公告,2025年第二季度,集团按合并报表口径完成发...
中化国际:拟发行股份购买资产 中化国际公告,公司拟以发行股份的方式向中国蓝星(集团)股份有限公司购买其所持有的南通星辰合成材料有限...
二连板直真科技:正在筹划定增事... 每经AI快讯,直真科技7月28日晚间披露股票交易异动公告称,公司目前正在筹划向特定对象发行股票事项,...
文远知行Robotaxi获沙特... 7月28日,国内自动驾驶科技公司文远知行(Nasdaq:WRD)宣布旗下Robotaxi获得沙特阿拉...