插入排序

来源:互联网 发布:做奥数题的软件 编辑:程序博客网 时间:2024/05/20 10:22

二、直接插入排序
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];

插入排序的程序

public static void insertSort(int[] array){
  
   int j=0;
  
   for(int i=1;i<array.length;i++){
   
    int temp=array[i];
    j=i-1;
    while(j>=0 && temp<array[j]){
    
     array[j+1]=array[j];
     j--;
    }
    array[j+1] = temp;
    
   }
  
   System.out.println(Arrays.toString(array));
  }
 

0 0
原创粉丝点击