将一个数据插入到已排序的有序数据里,得到一个有序的、个数加一的有序数据。适用于少量数据的排序时间复杂度为O(n^2)(一个元素最多可比较N次,一共N个元素).属于稳定排序(两个相等的数不会交换位置).属于内部排序(不需要访问外存储器)
包括:直接插入排序、二分插入排序、希尔排序
直接插入排序:
1.设置监视哨r[0],将待插入纪录的值赋给r[0]
2.设置开始查找的位置J
3.在数组中搜索,将第J的记录左移,直至r[0].key>=r[j].key
4.r[0]插入到r[j]
二分插入排序:
1.计算0~i-1的中间点与i上的点比较
2.在相应的半个范围内找插入位置,不断重复1的操作
3.确定位置后,将整个序列后移,插入元素
希尔排序:
1.将序列分成几组,对组内的记录分别进行排序(一般采用直接插入法)
2.在将几个组合为一组,分别再进行排序
3.最后只有一组的时候排序完成