八大排序之插入排序


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.     }  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值