服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - java数据结构之插入排序

java数据结构之插入排序

2021-02-02 11:44阿木侠 Java教程

这篇文章主要为大家详细介绍了java数据结构之插入排序的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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

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

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

简单例子:

java" id="highlighter_107893">
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
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)); 
   
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

延伸 · 阅读

精彩推荐