Java实现插入排序

插入排序基本原理

将待排序列表看成有序和无序的两部分,初始为有长度为1的有序数组和其后的无序数组。之后从无序数组中取出第一个数a与有序数组从后往前进行比较,如果a小于被比较的数则与之交换,否则说明a已经到了有序数组中合适的位置。此时,有序数组长度+1,无序数组长度-1,如此操作直到全部有序。

代码实现

    public static <T extends Comparable> void insertSort(T[] a ){
        for(int i = 1; i < a.length; i++){
            for(int j = i; j > 0; j--){
                if(a[j-1].compareTo(a[j])>0){
                    T t = a[j];
                    a[j] = a[j-1];
                    a[j-1] = t;
                }
                else
                    break;
            }
        }
    }
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • public class InsertSortNumber { public static void main(S...
    朱嘻嘻阅读 326评论 0 0
  • 插入排序(Insertion Sort),是一种简单直观并且稳定的排序算法。 从前到后取每个元素和之后的元素进行比...
    DouQing阅读 227评论 0 2
  • 1 初级排序算法 排序算法关注的主要是重新排列数组元素,其中每个元素都有一个主键。排序算法是将所有元素主键按某种方...
    深度沉迷学习阅读 1,463评论 0 1
  • 文|王不二 一、 在清朝最鼎盛的那几年,也是叫魂术最盛行的时期,妖术恐慌迅速在全国蔓延。 弘历对恐慌表露出深深地担...
    旅人还有平凡阅读 1,306评论 16 39
  • 前面真的是在吹牛 计划了很久,决定写点东西出来。到现在才真正开始动笔! 本来打算弄个订阅号来装装逼,做回老司机。结...
    上沙士阅读 410评论 0 0