学习笔记--数据结构与算法基础(青岛大学-王卓)--第八章排序

简介: 学习笔记--数据结构与算法基础(青岛大学-王卓)--第八章排序

视频链接:
在这里插入图片描述
学习链接:数据结构与算法基础(青岛大学-王卓)--第八章排序

本章知识框架
在这里插入图片描述

1.基本概念和排序方法概述

  • 什么是排序?

在这里插入图片描述

  • 排序方法的分类

在这里插入图片描述

内部排序和外部排序(按存储介质划分)
内部排序:在内存中进行排序
外部排序:将外部存储的数据传到内存中进行排序,排好后再交给外存
在这里插入图片描述
串行排序和并行排序(根据比较器来划分)
在这里插入图片描述
比较排序和基数排序(按操作来划分)
在这里插入图片描述
原地排序和非原地排序(按辅助空间来划分)
在这里插入图片描述
稳定排序和非稳定排序
在这里插入图片描述
例子:
稳定排序:
在这里插入图片描述
在这里插入图片描述

非稳定排序:
在这里插入图片描述
自然排序和非自然排序
在这里插入图片描述

  • 按排序依据原则和按排序所需工作量(学习相关排序算法)

在这里插入图片描述

2.插入排序

  • 基本思想

在这里插入图片描述

  • 插入操作

插入的位置:
在这里插入图片描述
如何查找插入的位置:
在这里插入图片描述

  • 直接插入排序

在这里插入图片描述
改进一下:
在这里插入图片描述
算法:
在这里插入图片描述

效率

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 二分插入排序

在这里插入图片描述
算法:
在这里插入图片描述
算法分析:
在这里插入图片描述
在这里插入图片描述

  • 希尔排序

在这里插入图片描述
基本思想:
在这里插入图片描述
例子:
在这里插入图片描述
在这里插入图片描述
特点:
在这里插入图片描述
算法:
在这里插入图片描述
在这里插入图片描述
算法分析:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.交换排序

  • 基本思想

在这里插入图片描述

  • 冒泡排序

基本思想:
在这里插入图片描述
规律:
在这里插入图片描述
算法:
在这里插入图片描述
算法改进:
在这里插入图片描述
算法分析:
在这里插入图片描述

  • 快速排序

基本思想:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
步骤:
在这里插入图片描述
算法:
在这里插入图片描述
在这里插入图片描述
算法分析:
在这里插入图片描述
在这里插入图片描述
快速排序不适于对原本有序或基本有序的记录序列进行排序。
在这里插入图片描述
在这里插入图片描述

4.选择排序

  • 简单选择排序

基本思想:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
算法:
在这里插入图片描述
算法分析:
在这里插入图片描述

  • 堆排序

堆的定义:
在这里插入图片描述
例子:
在这里插入图片描述
在这里插入图片描述
堆排序:
在这里插入图片描述
实现堆排序需要解决的二个问题:
在这里插入图片描述
解决问题2:
在这里插入图片描述
例子:
在这里插入图片描述
输出堆顶元素
在这里插入图片描述
取堆中最后一个元素替代
在这里插入图片描述
比较其左右孩子值的大小,并与其中较小者交换
在这里插入图片描述
没有到达叶子,继续循环
在这里插入图片描述
再次输出堆顶元素,依次循环以上操作
解决问题1:
堆的建立
在这里插入图片描述
在这里插入图片描述
调整从第n/2个元素开始,将以该元素为根的二叉树调整为堆
在这里插入图片描述
在这里插入图片描述
将以序号为n/2 -1的结点为根的二叉树调整为堆
在这里插入图片描述
在这里插入图片描述
再将以序号为n/2-2的结点为根的二叉树调整为堆(无需调整38<49,38<76)
在这里插入图片描述
再将以序号为n/2-3的结点为根的二叉树调整为堆
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
实现:
在这里插入图片描述
进行堆排序
在这里插入图片描述
算法:
在这里插入图片描述
算法分析:
在这里插入图片描述

5.归并排序

  • 基本思想

在这里插入图片描述
例子:
在这里插入图片描述

  • 如何将二个有序序列合成一个有序序列

在这里插入图片描述
在这里插入图片描述

  • 算法分析

在这里插入图片描述

6.基数排序

  • 基本思想

在这里插入图片描述
例子:
按个位有序分配,按十位有序分配,按百位有序分配
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 算法分析

在这里插入图片描述
在这里插入图片描述

7.外排序

外部排序指的是大文件的排序,即待排序的记录存储在外存储器上,待排序的文件无法一次装入内存,需要在内存和外部存储器之间进行多次数据交换,以达到排序整个文件的目的。

学习链接:外部排序算法总结

8.各种基本排序总结

  • 各种基本排序算法的比较

在这里插入图片描述

  • 时间性能上看各种排序算法

在这里插入图片描述
在这里插入图片描述

  • 空间性能上看各种排序算法

在这里插入图片描述

  • 各种排序算法的稳定性能

在这里插入图片描述

  • 各个排序算法的时间复杂度的下限(最坏时间复杂度)

在这里插入图片描述

相关文章
|
7月前
|
机器学习/深度学习 算法 安全
【无人机三维路径规划】基于非支配排序的鲸鱼优化算法NSWOA与多目标螳螂搜索算法MOMSA求解无人机三维路径规划研究(Matlab代码实现)
【无人机三维路径规划】基于非支配排序的鲸鱼优化算法NSWOA与多目标螳螂搜索算法MOMSA求解无人机三维路径规划研究(Matlab代码实现)
376 5
|
7月前
|
机器学习/深度学习 运维 算法
基于非支配排序遗传算法NSGAII的综合能源优化调度(Matlab代码实现)
基于非支配排序遗传算法NSGAII的综合能源优化调度(Matlab代码实现)
410 0
基于非支配排序遗传算法NSGAII的综合能源优化调度(Matlab代码实现)
|
8月前
|
机器学习/深度学习 算法 安全
【无人机3D路径规划】基于非支配排序遗传算法NSGAII的无人机3D路径规划研究(Matlab代码实现)
【无人机3D路径规划】基于非支配排序遗传算法NSGAII的无人机3D路径规划研究(Matlab代码实现)
311 1
|
7月前
|
机器学习/深度学习 算法 安全
【无人机三维路径规划】多目标螳螂搜索算法MOMSA与非支配排序的鲸鱼优化算法NSWOA求解无人机三维路径规划研究(Matlab代码实现)
【无人机三维路径规划】多目标螳螂搜索算法MOMSA与非支配排序的鲸鱼优化算法NSWOA求解无人机三维路径规划研究(Matlab代码实现)
272 0
|
7月前
|
机器学习/深度学习 算法 安全
【微电网】【创新点】基于非支配排序的蜣螂优化算法NSDBO求解微电网多目标优化调度研究(Matlab代码实现)
【微电网】【创新点】基于非支配排序的蜣螂优化算法NSDBO求解微电网多目标优化调度研究(Matlab代码实现)
230 0
|
8月前
|
机器学习/深度学习 算法 安全
【优化调度】基于matlab非支配排序遗传算法求解车辆充电调度优化问题研究(Matlab代码实现)
【优化调度】基于matlab非支配排序遗传算法求解车辆充电调度优化问题研究(Matlab代码实现)
161 0
|
7月前
|
存储 算法 搜索推荐
软考算法破壁战:从二分查找到堆排序,九大排序核心速通指南
专攻软考高频算法,深度解析二分查找、堆排序、快速排序核心技巧,对比九大排序算法,配套动画与真题,7天掌握45%分值模块。
320 1
软考算法破壁战:从二分查找到堆排序,九大排序核心速通指南
|
7月前
|
供应链 算法 Java
【柔性作业车间调度问题FJSP】基于非支配排序的多目标小龙虾优化算法求解柔性作业车间调度问题FJSP研究(Matlab代码实现)
【柔性作业车间调度问题FJSP】基于非支配排序的多目标小龙虾优化算法求解柔性作业车间调度问题FJSP研究(Matlab代码实现)
304 1
|
8月前
|
传感器 并行计算 算法
【无人机编队】基于非支配排序遗传算法II NSGA-II高效可行的无人机离线集群仿真研究(Matlab代码实现)
【无人机编队】基于非支配排序遗传算法II NSGA-II高效可行的无人机离线集群仿真研究(Matlab代码实现)
533 3
|
7月前
|
机器学习/深度学习 算法 安全
【无人机三维路径规划】基于非支配排序的鱼鹰优化算法NSOOA求解无人机三维路径规划研究(Matlab代码实现)
【无人机三维路径规划】基于非支配排序的鱼鹰优化算法NSOOA求解无人机三维路径规划研究(Matlab代码实现)
174 0

热门文章

最新文章