数据结构-排序算法

基于交换的排序算法

快速排序:

最优情况

最优情况下,每次找到的参考轴把数据分成均匀的两半,最后应该是一个平衡二叉树状态;二叉树的层数(logn)即为递归需要进行的次数,并且每轮递归结束时,都将二叉树遍历了一遍(n),所以最优的情况下,时间复杂度为O(nlogn)

最坏情况

最坏情形下,为正序或逆序排列,二叉树画出来应该是一棵斜树,并且需要经过n-1次递归调用才能完成,且第i次划分需要经过n‐i次关键字的比较才能找到第i个记录,也就是枢轴的位置,所以:

最终的时间复杂度应该O(n2)

平均复杂度:

枢轴可以随机的在第k的位置(1≤k≤n):

n-1是分割所使用的比较次数。因为基准值是相当均匀地落在排列好的数列次序之任何地方,总和就是所有可能分割的平均。

这个意思是,平均上快速排序比理想的比较次数,也就是最好情况下,只大约比较糟39%。这意味着,它比最坏情况较接近最好情况。这个快速的平均运行时间,是快速排序比其他排序算法有实际的优势之另一个原因。

算法:

cpp 复制代码
#include<iostream>
#include<cstdio>
#include <ctime>

using namespace std;


void Random(int *a,int n,int l,int r)//生成范围在l~r的随机数
{
	srand(time(0));  //设置时间种子
	for(int i=0;i<n;i++){
		a[i]=rand()%(r-l+1)+l;//生成区间r~l的随机数
	}
}

int Partition(int a[],int l,int r ){
    int p = a[l];
    while(l<r){
        while(l<r && a[r]>=p){
            r -- ;
        }
        a[l] = a[r];
        while(l<r && a[l]<=p){
            l++;
        }
        a[r] = a[l];
    }
    a[l] = p;
    return l;
}

void quick_sort(int q[],int l ,int r){

    if(l<r){
        int p = Partition(q,l,r);
        quick_sort(q,l,p-1);
        quick_sort(q,p+1,r);
    }


}

int main(){
    int a[10];
    Random(a,10,1,100);//生成随机数的通常范围为0~32767,这里通过取模控制取值为0~100
    for(int i = 0;i<10;i++){
        cout<<a[i]<<" ";
    }
    cout<<endl;
    quick_sort(a,0,9);

    for(int i = 0;i<10;i++){
        cout<<a[i]<<" ";
    }

}
相关推荐
Fanfanaas10 分钟前
C++ 继承
java·开发语言·jvm·c++·学习·算法
lqqjuly13 分钟前
模型合并与融合:理论、算法与可运行实现—从损失曲面几何到多模型融合
算法
memcpy022 分钟前
LeetCode 2144. 打折购买糖果的最小开销【贪心】
算法·leetcode·职场和发展
ID_180079054731 小时前
淘宝商品详情数据接口深度解析:架构、鉴权、数据结构与实战
数据结构·架构
散峰而望2 小时前
【算法练习】算法练习精选:陶陶摘苹果(基础+升级)、Music Notes、字串变换,你能AC几道?
数据结构·c++·算法·leetcode·贪心算法·github·动态规划
暗夜猎手-大魔王2 小时前
转载--Hermes Agent 04 | Agent 主循环:一次对话背后发生了什么
人工智能·python·算法
手写码匠2 小时前
华为云Flexus+DeepSeek征文|基于华为云Flexus X实例 + Dify + DeepSeek 构建企业级智能知识库问答系统实战
人工智能·深度学习·算法·aigc
凤凰院凶涛QAQ2 小时前
《Java版数据结构 & 集合类剖析》集合框架的封装设计与顺序表:“从 Iterable 到 ArrayList:集合框架的‘职业树“
java·开发语言·数据结构
吴可可1232 小时前
Win7上开发CAD2004自定义实体全解析
c++·算法
YXXY3132 小时前
二叉树中的深搜算法介绍
算法