八大排序之插入排序

来源:互联网 发布:剑龙网络 编辑:程序博客网 时间:2024/06/05 20:07

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 的位置。

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. /** 
  2.      * 插入排序 
  3.      */  
  4.     public static void insertSort(int []array){  
  5.         //13, 6, 20, 15, 1, 8, 1   
  6.         int j = 0;  
  7.         for (int i = 0; i < array.length; i++) {  
  8.               
  9.             int temp = array[i];  
  10.             j = i - 1;  
  11.             while(j >= 0 && temp < array [j]){  
  12.                   
  13.                 array[j+1] = array[j];  
  14.                 j--;  
  15. //              System.out.println("-------" + Arrays.toString(array));  
  16.             }  
  17.             array[j+1] = temp;  
  18.             System.out.println("++++++++++" + Arrays.toString(array));  
  19.         }  
  20.     }  

0 0
原创粉丝点击