1、算法概念:
每次从无序的数据中取出第一个元素,把它插入到有序的数据中的合适位置,使无序表变得有序。
2、算法思想:
假设待排序的记录存放在数组A[1...n]中,初始是,A[1]自成一个有序的序列,无序的数据为A[2...n],从i=2起直至i=n为止,依次将A[i]插入到当前有序的区域R[1,i-1],生成含n个记录的有序序列。
3、算法实现:
a、使用一个临时变量temp存储第i个元素(i>=1,下标从0开始)
b、比较temp和A[i-1],如果temp比A[i-1]小,则A[i]=A[i-1],即比temp大的元素集合依次往右移动一位。
c、将temp的值赋给A[i];
插入排序相对较简单,每一个数每次和他前面的数比较,找到第一个比较小的和最后一个比他大的数中间插入。实现过程是:用变量存储起来,只要比他大就将比他大的值赋值给它原来的位置,然后做标前移,重复上述步骤,直到不再满足比他大,将t存储emp变量值赋值给不比它大的数据的坐标 +1 的位置。
- /**
- * 插入排序
- */
- public static void insertSort(int []array){
- //13, 6, 20, 15, 1, 8, 1
- int j = 0;
- for (int i = 0; i < array.length; i++) {
- int temp = array[i];
- j = i - 1;
- while(j >= 0 && temp < array [j]){
- array[j+1] = array[j];
- j--;
- // System.out.println("-------" + Arrays.toString(array));
- }
- array[j+1] = temp;
- System.out.println("++++++++++" + Arrays.toString(array));
- }
- }