插入排序(简单排序)

目录

插入排序

排序原理

代码展示

插入排序的时间复杂度分析


    

嘻嘻,今天我们来学习一个简单的排序,

大家平时玩扑克牌吗?

如果有,插入排序 就很好理解啦!

跟着Nick一起来看看吧!

    

插入排序

      插入排序( lnsertion sort )是一种简单直观且稳定的排序算法。

   

      插入排序的工作方式非常像人们排序一手扑克牌一样。开始时,我们的左手为空并且桌子上的牌面朝下。然后,我们每次从桌子上拿走一张牌并将它插入左手中正确的位置。为了找到一张牌的正确位置,我们从右到左将它与已在手中的每张牌进行比较。

     

需求

排序前:{4,3,2,10,12,1,5,6}

排序后:{1,2,3,4,5,6,10,12}

     

排序原理

  1. 把所有的元素分为两组,已经排序的和未排序的;
  2. 找到未排序的组中的第一个元素,向已经排序的组中进行插入;
  3. 倒叙遍历已经排序的元素,依次和待插入的元素进行比较,直到找到一个元素小于等于待插入元素,那么就把待插入元素放到这个位置,其他的元素向后移动一位;

       

   

代码展示

Insertion方法

public class Insertion {
    public static void sort(Comparable[] a){
        for (int i = 1; i <a.length; i++) {
            for (int j = i; j>0; j--) {
                //比较索引j处的值和j-1处的值,如果j-1>j则交换,否则找到合适位置了,退出
                if (greater(a[j-1],a[j])){
                    exch(a,j-1,j);
                }else{
                    break;
                }
            }
        }

    }

    /*比较v元素是否大于w元素*/
    private static boolean greater(Comparable v,Comparable w){
        return v.compareTo(w)>0;
    }

    /*数组元素i和j交换位置*/
    private static void exch(Comparable[] a,int i,int j){
        Comparable temp;
        temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }
}
/*
心得
1.为什么是i=1;第一个数i=0是已排序,用于比较
2.为什么是i<a.length;我要摸到手里所有的牌
3.为什么是j=i;未排序的初始值
4.为什么是j>0,若j>=0;j-1则j=-1,会出现索引越界异常(悟了)
5.为什么要break;前面的已经比较好了,不需要判断了
* */

   测试类

import java.util.Arrays;

public class InsertionTest {
    public static void main(String[] args) {
        Integer[] a={4,3,2,10,12,1,5,6};
        Insertion.sort(a);
        System.out.println(Arrays.toString(a));
    }
}

   

插入排序的时间复杂度分析

   

      插入排序使用了双层for循环,其中内层循环的循环体是真正完成排序的代码,所以,我们分析插入排序的时间复杂度,主要分析一下内层循环体的执行次数即可。 最坏情况,也就是待排序的数组元素为{12,10,6,5,4,3,2,1},

    

那么︰

  

比较的次数为:

(N-1)+(N-2)+(N-3)+...+2+1=((N-1)+1)(N-1)/2=N^2/2-N/2;

  

交换的次数为:

(N-1)+(N-2)+(N-3)+...+2+1=((N-1)+1)*(N-1)/2=N^2/2-N/2;

   

总执行次数为:

(N^2/2-N/2)+(N^2/2-N/2)=N^2-N;

    

      按照大O推导法则,保留函数中的最高阶项那么最终插入排序的时间复杂度为O(N^2)。

           

今天Nick的笔记分享就到这里啦!

下一篇 希尔排序 更精彩!

喜欢的记得一键三连哦~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奶鲨要抱抱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值