数据结构——五十六、排序的基本概念(王道408)

文章目录

前言

本文介绍了排序的基本概念与评价指标。排序是将元素按关键字重新排列的过程,评价标准包括时间复杂度、空间复杂度和稳定性(相同关键字元素顺序是否改变)。排序分为内部排序(数据全在内存)和外部排序(数据量过大需磁盘读写)。文章指出稳定算法未必优于不稳定算法,需视需求而定,并提供了可视化学习资源链接。

一.什么是排序

  • 排序(sort) ,就是重新排列表中的元素,使表中的元素满足按关键字有序 的过程。
    输入:n 个记录 R 1 , R 2 , ... , R n R_{1},R_{2},\dotsc ,R_{n} R1,R2,...,Rn,对应的关键字为 k 1 , k 2 , ... , k n k_{1},k_{2},\dotsc ,k_{n} k1,k2,...,kn。
    输出:输入序列的一个重排 R 1 , R 2 , ... , R n R_{1}, R_{2}, \dotsc, R_{n} R1,R2,...,Rn,使得有 k 1 ≤ k 2 ≤ ... ≤ k n k_{1}\leq k_{2}\leq\dotsc\leq k_{n} k1≤k2≤...≤kn。(也可递减)

二.排序算法的评价指标

1.内容

  • 时间复杂度
  • 空间复杂度
  • 算法的稳定性。若待排序表中有两个元素 R i R_i Ri和 R j R_j Rj,其对应的关键字相同即 k e y i = k e y j key_i=key_j keyi=keyj,且在排序前 R i R_i Ri在 R j R_j Rj的前面,若使用某一排序算法排序后, R i R_i Ri仍然在 R j R_j Rj的前面,则称这个排序算法是稳定的,否则称排序算法是不稳定的。

2.具体例子

  1. 两个3的顺序未改变,稳定
  2. 两个3的顺序改变,不稳定

问:稳定的排序算法一定比不稳定的好?

答:不一定,要看实际需求。

三.内部排序

  • 数据都在内存中
  • 关注如何使算法时、空复杂度更低

四.外部排序

  • 数据太多,无法全部放入内存
  • 关注如何使算法时、空复杂度更低,还要关注如何使读/写磁盘次数更少

五.知识回顾与重要考点


一个神奇的学习网站

结语

四更😉
如果想查看更多章节,请点击:一、数据结构专栏导航页

相关推荐
野犬寒鸦2 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
wenzhangli72 小时前
ooderA2UI BridgeCode 深度解析:从设计原理到 Trae Solo Skill 实践
java·开发语言·人工智能·开源
霖霖总总2 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow68892 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法
灵感菇_2 小时前
Java 锁机制全面解析
java·开发语言
wazmlp0018873692 小时前
python第三次作业
开发语言·python
娇娇乔木2 小时前
模块十一--接口/抽象方法/多态--尚硅谷Javase笔记总结
java·开发语言
明月醉窗台2 小时前
qt使用笔记六之 Qt Creator、Qt Widgets、Qt Quick 详细解析
开发语言·笔记·qt
逍遥德2 小时前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
wangjialelele2 小时前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先