八大排序之图文详解(上)

简介: 八大排序之图文详解(上)

前言

数据结构中,排序是非常重要的内容,也是未来面试和笔试的重点。

本文代码是Java




目录

前言

一、插入排序

(一)直接插入排序

(二)希尔排序

二、选择排序

(一)选择排序
(二)堆排序

三、交换排序

(一)冒泡排序

(二)快速排序

四、归并排序

(一)归并排序

五、计数排序

六、其他排序

结语


一、插入排序

(一)直接插入排序

将一条记录插入到已排好的有序表中,从而得到一个新的、记录数量增1的有序表。

适用于顺序表、链表

排序过程如下:

代码:

public static void InlineSort(int[] arr){
        for (int i = 1; i < arr.length; i++) {
            if(arr[i] < arr[i-1]){
                int tmp = arr[i];
                int j = i-1;
                for (; j >= 0; j--) {
                    if(arr[j]>tmp){
                        arr[j+1] = arr[j];
                    }else{
                        break;
                    }
                }
                arr[j+1] = tmp;
            }
        }
    }

时间复杂度:O(n^2)

空间复杂度:O(1)

稳定性:稳定

(二)希尔排序

仅适用于顺序表,不适用于链表

记录按下标的一定增量分组,对每组使用直接插入排序算法排序

排序过程如下:



代码:

public static void shellSort(int[] arr){
        int len = arr.length;
        int d = len/2;//组数,数据之间的间距
        while(d >= 1){
            for(int i = 0; i < d; i++){
                for (int j = i+d; j < len; j+=d) {
                    int tmp = arr[j];
                    int k = j-d;
                    for (; k >= 0; k-=d) {
                        if(tmp < arr[k]){
                            arr[k+d] = arr[k];
                        }else{
                            break;
                        }
                    }
                    arr[k+d] = tmp;
                }
            }
            d /= 2;
        }
    }

时间复杂度:O(n^1.3)

空间复杂度:O(1)

稳定性:不稳定

二、选择排序

(一)选择排序

在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
顺序表和链表都适用

排序过程:

代码:

public static void selectSort(int[] arr){
        int left = 0;
        int right = arr.length-1;
        while(left < right){
            int min = left;
            int max = right;
            for (int i = left; i <= right; i++) {
                if(arr[i] < arr[min]){
                    min = i;
                }
                if(arr[i] > arr[max]){
                    max = i;
                }
            }
            //交换
            swap(arr,min,left);
            if(left == max){
                max = min;
            }
            swap(arr,max,right);
            left++;
            right--;
        }
    }
    //交换
    public static void swap(int[] arr, int s1, int s2) {
        int tmp = arr[s1];
        arr[s1] = arr[s2];
        arr[s2] = tmp;
    }

时间复杂度:O(n^2)

空间复杂度:O(1)

稳定性:不稳定

该排序与数据是否有序无关

(二)堆排序

建立大根堆 -> 把堆顶与最末尾元素交换,直到建立有序的小根堆

排序过程:


代码:

    public static void heapSort(int[] arr){
        //使arr成为大根堆
        int len = arr.length;
        for (int i = (len-1-1)/2; i >= 0; i--) {
            shiftDown(arr, i, len-1);
        }
        while(len > 0){
            //将堆顶与堆末尾交换
            swap(arr,0,len-1);
            len--;
            shiftDown(arr,0,len-1);
        }
    }
    //向下调整
    public static void shiftDown(int[] arr, int parent, int k){
        int child = parent*2+1;
        while(child <= k){
            if(child+1<=k && arr[child+1]>arr[child]){
                child++;
            }
            if(arr[child] > arr[parent]){
                swap(arr,parent,child);
                parent = child;
                child = parent*2+1;
            }else{
                break;
            }
        }
    }
    //交换
    public static void swap(int[] arr, int s1, int s2){
        int tmp = arr[s1];
        arr[s1] = arr[s2];
        arr[s2] = tmp;
    }
相关文章
|
存储
八大排序之图文详解(下)
八大排序之图文详解(下)
|
存储 搜索推荐 算法
算法给小码农八大排序 八奇计只为宝儿姐
算法给小码农八大排序 八奇计只为宝儿姐
113 0
|
iOS开发 数据处理 C#
IOS开发---菜鸟学习之路--(二十三)-直接利用键值对的方式来处理数据的感想
首先声明,本文纯粹只是做为本人个人新手的理解。文中的想法我知道肯定有很多地方是错的。 但是这就是我作为一个新人的使用方法,对于大牛非常欢迎指导,对于喷子请绕道而行。 由于这是早上跟我学长讨论数据处理时,想到把我的实现手法写个说明,所以就写了。
892 0
八大基础排序总结
前言 大概花了一周的时间把八大基础排序过了一遍,这篇博文主要是用来回顾一下八大基础排序的要点和一些总结~ 回顾: 冒泡排序就这么简单 选择排序就这么简单 插入排序就这么简单 快速排序就这么简单 归并排序就这么简单 堆排序就这么简单 希尔排序就这么简单 基数排序就这么简单 总的来说:快速排序是用得比较广泛的一个排序,也是经常出现的一个排序,应该重点掌握~ 二、八大排序总结 2.1冒泡排序 思路: 俩俩交换,大的放在后面,第一次排序后最大值已在数组末尾。
1159 0
|
搜索推荐
七大常见排序,你究竟懂几个?(上)(1)
七大常见排序,你究竟懂几个?(上)
122 0
七大常见排序,你究竟懂几个?(上)(1)
|
人工智能 安全 数据处理
阿里云产品手册--(为了无法计算的价值)最新版
阿里云创立于 2009 年,是全球领先的云计算及人工智能科技公 司,为 200 多个国家和地区的企业、开发者和政府机构提供服务。 阿里云致力于以在线公共服务的方式,提供安全、可靠的计算和 数 据 处 理 能 力 ,让 计 算 和 人 工 智 能 成 为 普 惠 科 技 。 2 0 1 7 年 1 月 阿 里云成为奥运会全球指定云服务商,并且在 2020 年东京奥运会上 首次实现了全程云上奥运转播。
阿里云产品手册--(为了无法计算的价值)最新版
关于各类「区间和」问题如何选择解决方案(含模板)| Java 刷题打卡
关于各类「区间和」问题如何选择解决方案(含模板)| Java 刷题打卡
|
开发工具
【排序引论】第二章 单机排序问题
【排序引论】第二章 单机排序问题
65 0
【排序引论】第二章 单机排序问题
|
9月前
|
算法 程序员
八大排序源码(含优化)
八大排序源码(含优化)
|
1月前
|
存储 人工智能 算法
【C++数据结构——内排序】二路归并排序(头歌实践教学平台习题)【合集】
本关任务是实现二路归并算法,即将两个有序数组合并为一个有序数组。主要内容包括: - **任务描述**:实现二路归并算法。 - **相关知识**: - 二路归并算法的基本概念。 - 算法步骤:通过比较两个有序数组的元素,依次将较小的元素放入新数组中。 - 代码示例(以 C++ 为例)。 - 时间复杂度为 O(m+n),空间复杂度为 O(m+n)。 - **测试说明**:平台会对你编写的代码进行测试,提供输入和输出示例。 - **通关代码**:提供了完整的 C++ 实现代码。 - **测试结果**:展示代码运行后的排序结果。 开始你的任务吧,祝你成功!
36 10

热门文章

最新文章