插入排序
2017-08-13 本文已影响0人
flame_ash
算法描述:
插入排序(套用百度百科的解释):插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。
代码实现:
/**
* 插入排序
* 思想:1.遍历数组,每次遍历都假定 该元素之前的数列已经是有序的,
* 2.这样循环一遍就能保证所有的元素都是有序的
*
* @param array
*/
public static void insertSort(int[] array) {
for (int i = 1; i < array.length; i++) {//注意 i是从1开始(因为最开始是假设第一个元素是排好序的)
int j;
int insertedNum = array[i];
for (j = i - 1; j >= 0 && array[j] > insertedNum; j--) {//每当选定一个待插入的元素,从后往前找到那个待插入元素的位置,比待插入元素大的元素统一往后移动,为其腾出位置
array[j + 1] = array[j];
}
array[j + 1] = insertedNum;//遍历完一遍之后,找到对应值得索引,然后将其插入进去
}
}