内部排序与外部排序

转载自:https://blog.csdn.net/hq942845204/article/details/80303762
本篇文章主要介绍内部排序与外部排序的知识,如果你和我一样还不知道内部排序和外部排序为何物的话,不妨看看我的理解

正文

由于待排序的记录数量不同,使得排序过程中涉及的存储器不同,可将排序方法分为两大类:内部排序与外部排序。

概念

  • 内部排序:待排序记录存放在计算机随机存储器中(说简单点,就是内存)进行的排序过程。
  • 外部排序:待排序记录的数量很大,以致于内存不能一次容纳全部记录,所以在排序过程中需要对外存进行访问的排序过程。

从概念我们可以清晰的看到二者的区别

  • 衡量效率的方法

    • 内部排序:比较次数,也就是时间复杂度
    • 外部排序:IO次数,也就是读写外存的次数
  • 排序方法
    • 内部排序:插入排序、快速排序、选择排序、归并排序、基数排序等
    • 外部排序:
      先来了解下外部排序的过程吧。
      外部排序基本上由两个相对独立的阶段组成。首先,按可用内存大小,将外存上含n个记录的文件分成若干长度为l的子文件或段,依次读入内存并利用有效的内部排序方法对他们进行排序,并将排序后得到的有序子文件重新写入外存,通常称这些有序子文件为归并段;然后,对这些归并段进行逐趟归并,使归并段逐渐由小至大,直至得到整个有序文件为止。
      好了,读了上面这段文字之后,我们可以知道,第一阶段就是内部排序,这个我们都知道怎么做,那么第二阶段呢?也就是归并的过程是怎么实现的,常用的有两种方法,一,多路平衡归并;二,置换-选择排序

猜你喜欢

转载自blog.csdn.net/L_X_Y_HH/article/details/81867899
今日推荐