排序:将一组杂乱无章的数据按一定规律顺次排列起来,即,将无序序列排成一个有序序列(由小到大或由大到小)的运算
    排序方法的分类:
    (1)按存储介质分:
    ①内部排序:数据量不大,数据在内存,无需内外存交换数据
    ②外部排序:数据量较大、数据在外存(文件排序)
    外部排序时,要将数据分批调入内存来排序,中间结果还要及时放入外存,显然外部排序要复杂的多
    (2)按比较器个数分:
    ①串行排序:单处理机(同一时刻比较一对元素)
    ②并行排序:多处理机(同一时刻比较多对元素)
    (3)按主要操作分:
    ①比较排序:用比较的方法(插入排序、交换排序、选择排序、归并排序)
    ②基数排序:不比较元素的大小,仅仅根据元素本身的取值确定其有序位置
    (4)按辅助空间分:
    ①原地排序:辅助空间用量为O(1)的排序方法(所占的辅助存储空间与参加排序的数据量大小无关)
    ②非原地排序:辅助空间用量超过O(1)的排序方法
    (5)按稳定性分:
    ①稳定排序:能够使任何数值相等的元素,排序以后相对次序不变
    ②非稳定性排序:不是稳定排序的方法
    排序的稳定性只对结构类型数据排序有意义,排序方法是否稳定并不能衡量一个排序算法的优劣
    (6)按自然性分:
    ①自然排序:输入数据越有序,排序的速度越快的排序方法
    ②非自然排序:不是自然排序的方法
    存储结构——记录序列以顺序表存储
    #define MAXSIZE 20 //设记录不超过20个
    typedef int KeyType; //设关键字为整型量
    Typedef struct{ //定义每个记录(数据元素)的结构
    KeyType key; //关键字
    InfoType otherinfo; //其他数据项
    }RedType;
    Typedef struct{ //定义顺序表的结构
    RedType r[MAXSIZE+1]; //存储顺序表的向量
    //r[0]一般作哨兵或缓冲区
    int length; //顺序表的长度
    }SqList;