七大排序(简洁思路版)

1.冒泡排序

从1扫到n,当前位置和下一个位置比较大小,大的放后面,一直swap(),这样到最后的时候就是当前全局最大,之后n就要--

2.快速排序和归并排序

快并排序是从上往下,归并排序是从下往上

快速排序一般的实现为

cpp 复制代码
void quicksort(int beginarray,int endarray){//不符合工程要求,要对于swap进行封装
    if(beginarray>=endarray){
        return ;
    }
    int baseval=a[beginarray];
    int pl=beginarray,pr=endarray;
    while(pl<pr){
        while(pl<pr&&a[pl]<=baseval){//再合理的范围内进行访问,找到第一个比基准大的数字
            pl++;
        }
        while(pr<pr&&a[pr]>=baseval){//再合理的范围内进行访问,找到第一个比基准大的数字
            pr--;
        }
        swap(a[pl],a[pr]);//将大和小进行交换
    }
    swap(a[pl],baseval);//最后退出的那个位置一定是基准
    quicksort(beginarray,pl-1);
    quicksort(pl+1,endarray);
    return ;
}

归并排序一般的实现为

cpp 复制代码
void Mergesort(int l,int r){
    if(l>=r)return ;
    int mid=l+r>>1;
    Mergesort(l,mid);
    Mergesort(mid+1,r);
    int l1=l,l2=mid+1,tmp=0;
    while(l1<=mid&&l2<=r){
        if(a[l1]>=a[l2]){
            c[tmp++]=a[l2++];            
        }else{
            c[tmp++]=a[l1++];
        }
    }
    while(l1<=mid)c[tmp++]=a[l1++];
    while(l2<=r)c[tmp++]=a[l2++];
    for(int i=0;i<tmp;i++){
        a[i+l]=c[i];
    }
}

归并排序是稳定的,时间复杂度按道理来说都是nlog(n)的时间复杂度,快速排序最大的优势在于不用开辟空间,而归并排序空间复杂度是O(n)的

3.直接选择排序

和冒泡排序有点像,但是冒泡排序实在数组上两两进行交换,直接选择排序是,扫一遍,确定最大的元素的下标在哪,往数组末尾加,思路一样,实现的方式有点不一样

4.堆排序

堆排序和直接选择排序是类似的思路,选择最大的,放到末尾去,直接选择排序是直接遍历,但是堆排序并不是,堆排序使用的是维护一个最大堆来快速的确定最大值是什么

5.直接插入排序

从左到右,遍历每一个数字,在每一个位置的操作是,只看当前位置以及左边的,我看我这个数字应该放在哪里就放过去,切记,不管后面,只看前面,时间复杂度高到O(n^2)了

6.希尔排序

先确定步长,一般是总长度一直 / 2 ,就类似于len*n+1就是,假设步长4,那就是1 5 9 13 这些下边进行插入排序,然后就直接缩小步长排序,最终得到结果

相关推荐
深邃-1 天前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
We་ct1 天前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮1 天前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 天前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove1 天前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung1 天前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了1 天前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL1 天前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰1 天前
C++ 排列组合完整指南
开发语言·c++·算法