欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java数据结构及算法实例:插入排序 Insertion Sort

程序员文章站 2024-03-05 11:49:54
/** * 选择排序的思想: * 每次循环前,数组左边都是部分有序的序列, * 然后选择右边待排元素,将其值保存下来 * 依次和左边已经排好...
/** 
 * 选择排序的思想: 
 * 每次循环前,数组左边都是部分有序的序列, 
 * 然后选择右边待排元素,将其值保存下来 
 * 依次和左边已经排好的元素比较 
 * 如果小于左边的元素,就将左边的元素右移一位 
 * 直到和最左边的比较完成,或者待排元素不比左边元素小 
 */ 
package al; 
public class insertionsort { 
   
  public static void main(string[] args) { 
     
    insertionsort insertsort = new insertionsort(); 
    int[] elements = { 14, 77, 21, 9, 10, 50, 43, 14 }; 
    // sort the array 
    insertsort.sort(elements); 
    // print the sorted array 
    for (int i = 0; i < elements.length; i++) { 
      system.out.print(elements[i]); 
      system.out.print(" "); 
    } 
  } 
   
  /** 
   * @author 
   * @param array 待排数组 
   */ 
  public void sort(int[] array) { 
    // min to save the minimum element for each round 
    int key; // save current element 
    for(int i=0; i<array.length; i++) { 
      int j = i;  // current position 
      key = array[j]; 
      // compare current element 
      while(j > 0 && array[j-1] > key) { 
        array[j] = array[j-1]; //shift it 
        j--;  
      } 
      array[j] = key; 
     
    } 
  } 
}