欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

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

时间:2021-02-19 15:21:00|栏目:JAVA代码|点击:
/** 
 * 选择排序的思想: 
 * 每次循环前,数组左边都是部分有序的序列, 
 * 然后选择右边待排元素,将其值保存下来 
 * 依次和左边已经排好的元素比较 
 * 如果小于左边的元素,就将左边的元素右移一位 
 * 直到和最左边的比较完成,或者待排元素不比左边元素小 
 */ 
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; 
     
    } 
  } 
} 

上一篇:Spring中DAO被循环调用的时候数据不实时更新的解决方法

栏    目:JAVA代码

下一篇:Intellij IDEA下Spring Boot热切换配置

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

本文地址:http://www.codeinn.net/misctech/66124.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有