简单排序--插入排序(三)

9 篇文章 1 订阅

前言

插入排序算法任然需要O(N^2)的时间,但是一般情况下,他要比冒泡排序快一倍,比选择排序要快一点。
在这里插入图片描述

一、插入排序

假定排序从中间开始,可以更好的理解插入排序。此时,队列左边已经排好序,在队列中间标记一个元素,在这个作为标记的元素左边已经是局部有序,(注意,局部有序在冒泡排序和选择排序中不会出现)这个被标记的元素右边是未排序的。我们需要做的是在左边有序的队列中的适当位置插入被标记的元素。这意味着左边有序的队列需要先向右移腾出空间。而被标记的元素需要出列,以提供位移空间。

示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。

插入排序的代码如下:

 public void insertionSort(){
        int left , right;
        for (right = 1;right<arr.length;right++){
            int temp = arr[right];
            left = right;
            while (left>0&&arr[left-1] >=temp){
                arr[left] = arr[left-1];
                left--;
            }
            arr[left] = temp;
            System.out.println("排序前:"+ Arrays.toString(arr));

        }
    }

在外层的for循环中,right从变量从1开始,向右移动。它标记了未排序部分的最左端的数据。而内层循环while中,left变量冲right变量开始,向左移动。直到temp变量小于等于left所指的数组数据项,或者它不能再往做移动为止。while中的每一趟都向右移动了一个已排序的数据项。在这里插入图片描述

测试

public class Main {

    public static void main(String[] args) {

        Random random = new Random();
        int[] arr = new int[10];
        for (int i = 0; i < arr.length; i++) {
            arr[i] = random.nextInt(100);
        }
        System.out.println("排序前:"+Arrays.toString(arr));
        InsertSort insertSort = new InsertSort(arr);
        insertSort.insertionSort();
        System.out.println("排序后:"+Arrays.toString(arr));
    }
}

结果:

排序前:[45, 92, 15, 27, 45, 18, 8, 24, 43, 56]
排序前:[45, 92, 15, 27, 45, 18, 8, 24, 43, 56]
排序前:[15, 45, 92, 27, 45, 18, 8, 24, 43, 56]
排序前:[15, 27, 45, 92, 45, 18, 8, 24, 43, 56]
排序前:[15, 27, 45, 45, 92, 18, 8, 24, 43, 56]
排序前:[15, 18, 27, 45, 45, 92, 8, 24, 43, 56]
排序前:[8, 15, 18, 27, 45, 45, 92, 24, 43, 56]
排序前:[8, 15, 18, 24, 27, 45, 45, 92, 43, 56]
排序前:[8, 15, 18, 24, 27, 43, 45, 45, 92, 56]
排序前:[8, 15, 18, 24, 27, 43, 45, 45, 56, 92]
排序后:[8, 15, 18, 24, 27, 43, 45, 45, 56, 92]

总结

在每趟结束时,在将temp位置项插入后,比right变量下标小的数据项都是局部有序的。
在第一趟中,它对多比较一次,第二趟最多比较两次,一次类推。最后一趟最多,比较N-1次。因此有
1 + 2 + 3 + . . . . . . . . . . . . . . . + ( N − 1 ) = N ∗ ( N − 1 ) / 2 1+ 2+3+...............+(N-1) = N*(N-1)/2 1+2+3+...............+(N1)=N(N1)/2
然而,因为每趟排序发现插入插入点之前,平均只有全体数据项的一半真的进行了比较,我们chuyi2得到
N ∗ ( N − 1 ) / 4 N*(N-1)/4 N(N1)/4

复制的次数大致等于比较次数,然而,一次复制与一次交换的事件耗费不同,所以相对于随机数据,这个算法比冒泡排序快一倍,比选择排序略快。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值