algorithm-reading

Basics Sorting - 基础排序算法

算法复习——排序

时间限制为1s时,大O为10000000时勉强可行,100,000,000时很悬。

算法分析

  1. 时间复杂度-执行时间(比较和交换次数)
  2. 空间复杂度-所消耗的额外内存空间
    • 使用小堆栈或表
    • 使用链表或指针、数组索引来代表数据
    • 排序数据的副本

对具有重键的数据(同一组数按不同键多次排序)进行排序时,需要考虑排序方法的稳定性,在非稳定性排序算法中需要稳定性时可考虑加入小索引。

稳定性:如果排序后文件中拥有相同键的项的相对位置不变,这种排序方式是稳定的。

常见的排序算法根据是否需要比较可以分为如下几类:

  • Comparison Sorting
    1. Bubble Sort
    2. Selection Sort
    3. Insertion Sort
    4. Shell Sort
    5. Merge Sort
    6. Quck Sort
    7. Heap Sort
  • Bucket Sort
  • Counting Sort
  • Radix Sort

从稳定性角度考虑可分为如下两类:

  • 稳定
  • 非稳定

Reference