插入排序

插入排序就是把当前待排序的元素插入到一个已经排好序的列表里面。 一个非常形象的例子就是右手抓取一张扑克牌,并把它插入左手拿着的排好序的扑克里面。

     插入排序的最坏运行时间是O(n2), 所以并不是最优的排序算法。

     如果输入数组已经是排好序的话,插入排序出现最佳情况,其运行时间是输入规模的一个线性函数。

     如果输入数组是逆序排列的,将出现最坏情况。平均情况与最坏情况一样,其时间代价是Θ(n2)。

简单例子:

public class Demo6 {

public static void main(String[] args) {   
    //定义一个整型数组   
    int[] nums = new int[]{4,3,-1,9,2,1,8,0,6};   
    //打印没有进行排序的数组   
    System.out.println("没有排序之前的结果:" + Arrays.toString(nums));   
    for(int index=0; index<nums.length; index++) {   
      //获得需要插入的数值   
      int key = nums[index];   
      //取得下标值   
      int position = index;   
       /循环比较之前排序好的数据,找到合适的地方插入   
      while(position >0 && nums[position-1] > key) {   
        nums[position] = nums[position-1];   
        position--;   
      }   
      nums[position] = key;   
    }   
    //打印排序后的结果   
    System.out.println("排序后的结果:" + Arrays.toString(nums));   
  }   

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容