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

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

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

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

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.各种基本排序总结

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

在这里插入图片描述

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

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

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

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

目录
打赏
0
0
0
0
59
分享
相关文章
JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码)
Array.sort() 是一个功能强大的方法,通过自定义的比较函数,可以处理各种复杂的排序逻辑。无论是简单的数字排序,还是多字段、嵌套对象、分组排序等高级应用,Array.sort() 都能胜任。同时,通过性能优化技巧(如映射排序)和结合其他数组方法(如 reduce),Array.sort() 可以用来实现高效的数据处理逻辑。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
C 408—《数据结构》图、查找、排序专题考点(含解析)
408考研——《数据结构》图,查找和排序专题考点选择题汇总(含解析)。
186 29
【C++数据结构——内排序】二路归并排序(头歌实践教学平台习题)【合集】
本关任务是实现二路归并算法,即将两个有序数组合并为一个有序数组。主要内容包括: - **任务描述**:实现二路归并算法。 - **相关知识**: - 二路归并算法的基本概念。 - 算法步骤:通过比较两个有序数组的元素,依次将较小的元素放入新数组中。 - 代码示例(以 C++ 为例)。 - 时间复杂度为 O(m+n),空间复杂度为 O(m+n)。 - **测试说明**:平台会对你编写的代码进行测试,提供输入和输出示例。 - **通关代码**:提供了完整的 C++ 实现代码。 - **测试结果**:展示代码运行后的排序结果。 开始你的任务吧,祝你成功!
176 10
【C++数据结构——内排序】希尔排序(头歌实践教学平台习题)【合集】
本文介绍了希尔排序算法的实现及相关知识。主要内容包括: - **任务描述**:实现希尔排序算法。 - **相关知识**: - 排序算法基础概念,如稳定性。 - 插入排序的基本思想和步骤。 - 间隔序列(增量序列)的概念及其在希尔排序中的应用。 - 算法的时间复杂度和空间复杂度分析。 - 代码实现技巧,如循环嵌套和索引计算。 - **测试说明**:提供了测试输入和输出示例,帮助验证代码正确性。 - **我的通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了代码运行的测试结果。 通过这些内容,读者可以全面了解希尔排序的原理和实现方法。
124 10
|
6月前
|
【C++数据结构——内排序】快速排序(头歌实践教学平台习题)【合集】
快速排序是一种高效的排序算法,基于分治策略。它的主要思想是通过选择一个基准元素(pivot),将数组划分成两部分。一部分的元素都小于等于基准元素,另一部分的元素都大于等于基准元素。然后对这两部分分别进行排序,最终使整个数组有序。(第一行是元素个数,第二行是待排序的原始关键字数据。本关任务:实现快速排序算法。开始你的任务吧,祝你成功!
160 7
【排序算法】八大排序(下)(c语言实现)(附源码)
本文继续学习并实现了八大排序算法中的后四种:堆排序、快速排序、归并排序和计数排序。详细介绍了每种排序算法的原理、步骤和代码实现,并通过测试数据展示了它们的性能表现。堆排序利用堆的特性进行排序,快速排序通过递归和多种划分方法实现高效排序,归并排序通过分治法将问题分解后再合并,计数排序则通过统计每个元素的出现次数实现非比较排序。最后,文章还对比了这些排序算法在处理一百万个整形数据时的运行时间,帮助读者了解不同算法的优劣。
293 7
【排序算法】八大排序(上)(c语言实现)(附源码)
本文介绍了四种常见的排序算法:冒泡排序、选择排序、插入排序和希尔排序。通过具体的代码实现和测试数据,详细解释了每种算法的工作原理和性能特点。冒泡排序通过不断交换相邻元素来排序,选择排序通过选择最小元素进行交换,插入排序通过逐步插入元素到已排序部分,而希尔排序则是插入排序的改进版,通过预排序使数据更接近有序,从而提高效率。文章最后总结了这四种算法的空间和时间复杂度,以及它们的稳定性。
294 8
|
9月前
|
解析排序算法:十大排序方法的工作原理与性能比较
解析排序算法:十大排序方法的工作原理与性能比较
256 9
数据结构与算法学习十三:基数排序,以空间换时间的稳定式排序,速度很快。
基数排序是一种稳定的排序算法,通过将数字按位数切割并分配到不同的桶中,以空间换时间的方式实现快速排序,但占用内存较大,不适合含有负数的数组。
122 0
数据结构与算法学习十三:基数排序,以空间换时间的稳定式排序,速度很快。

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等