首页 > 其他分享 >插入排序:简单而有效的排序方法

插入排序:简单而有效的排序方法

时间:2023-10-03 16:31:40浏览次数:33  
标签:arr 插入排序 元素 算法 数组 简单 排序

在计算机科学中,排序算法是一个重要且常见的主题,它们用于对数据进行有序排列。插入排序(Insertion Sort)是其中一个简单但有效的排序算法。本文将详细解释插入排序的原理和步骤,并提供Java语言的实现示例。

插入排序:简单而有效的排序方法_排序算法

插入排序的原理及性能分析

插入排序的核心思想是逐个将未排序的元素插入到已排序的部分中,构建有序序列。这个过程类似于整理扑克牌,每次拿出一张牌并将其插入到已排序的牌堆中。

插入排序:简单而有效的排序方法_排序算法_02

插入排序的步骤

插入排序的步骤可以简单概括为以下几个阶段:

  1. 初始状态: 将数组的第一个元素视为已排序部分,其余部分为未排序部分。
  2. 逐个插入: 从未排序部分选择一个元素,将其插入到已排序部分的正确位置。为了插入,将已排序部分中大于待插入元素的元素向右移动一个位置。
  3. 重复: 重复上述插入步骤,直到所有元素都被插入到已排序部分。
  4. 完成: 当算法完成时,整个数组就被排序了。

插入排序:简单而有效的排序方法_排序算法_03

Java实现插入排序

以下是使用Java语言实现插入排序算法的示例代码:

public class Test {

    public static void main(String[] args) {
        int[] arr = new int[]{5,2,4,6,7,1,3};
        insertionSort(arr);
    }


    public static void insertionSort(int[] arr){
        System.out.println("原始数组:"+ Arrays.toString(arr));
        //获取数组长度
        int len = arr.length;
        // 循环 len-1 次,进行数组排序。第一次将数组的第一个元素视为已排序的部分,
        // 每次将未排序部分的第一个元素插入到已排序的部分。
        for(int i = 1 ; i< len ; i++){
            //目标元素,未排序部分的第一个元素,即当前循环中要插入排序的元素
            int target  = arr[i];
            //已排序元素中的最后一个元素的下标
            int j = i-1;

            // 循环已排序的部分的数组,找到目标元素应该存放的下标
            while (j>= 0 && arr[j] > target ){
                // 如果插入元素小于当前元素,则将当前元素后移一位
                arr[j+1] = arr[j];
                // 当前已排序的数据比较元素的下标前移一位
                j--;
            }
            //将目标元素插入到正确的位置
            arr[j+1] = target;
            // 打印每趟排序完成后的数组状态,以便查看排序进度
            System.out.println("第"+i+"趟排序完成的数组:"+ Arrays.toString(arr));

        }
        System.out.println("排序完成的数组:"+ Arrays.toString(arr));

    }
}

以上代码演示了如何使用插入排序对一个整数数组进行排序。插入排序算法的核心思想是逐个将未排序的元素插入到已排序的部分,直到整个数组排序完成。

性能及优缺点的分析

插入排序(Insertion Sort)是一种简单但性能较差的排序算法,其性能取决于输入数据的初始顺序。以下是对插入排序性能的分析:

  • 时间复杂度

在最坏情况下,插入排序的时间复杂度为插入排序:简单而有效的排序方法_数组_04,其中n是数组的长度。这是因为在最坏情况下,每个元素都需要与已排序部分中的所有元素进行比较和移动。在最好情况下,如果输入数据已经接近有序,插入排序的时间复杂度可以降至O(n),因为很少需要移动元素。

  • 空间复杂度

插入排序是一种稳定排序算法,其空间复杂度为O(1),因为它只需要常量级别的额外空间来存储临时变量。

  • 稳定性

插入排序是一种稳定的排序算法,即具有相等键值的元素在排序后仍然保持相对顺序。

  • 适用性

插入排序适用于小型数据集或已接近排序状态的数据集。对于大型数据集,插入排序的性能会变得相对较差,并且不如一些更高级的排序算法,如快速排序或归并排序。

  • 优点

插入排序的优点是实现简单,易于理解和调试。在某些情况下,它可能比其他排序算法更快,尤其是对于小型数据集。

  • 缺点

插入排序的缺点是其时间复杂度较高,特别是在大型数据集上。对于大规模数据,更高效的排序算法通常更受欢迎。

总结

总的来说,插入排序是一种简单但性能较差的排序算法,主要用于教学和小型数据集。在实际应用中,通常会选择更高效的排序算法,以提高排序速度。

标签:arr,插入排序,元素,算法,数组,简单,排序
From: https://blog.51cto.com/xiuji/7693829

相关文章

  • 实验1 C语言输入输出和简单程序编写
    1.task.1 1#include<stdio.h>2intmain()3{4printf("O\n");5printf("<H>\n");6printf("II\n");78return0;9} task.1_11#include<stdio.h>2intmain()3{......
  • 重学OI#4 简单dp
    观前须知:本文顺序较为混乱,根据本人复习顺序写的,难度严格不递增dp不像数据结构可以套路性的将,以例题为主吧part1:树形dp树是一种非常好的结构,其天然的递归形态保证了最优子结构,使得dp有很好的发挥空间一般状态与子树和路径有关,也有时扯到叶子节点,所以不套路化,特殊情况可能会......
  • 【231003CHEM-1】电解硫酸铜溶液 化学方程式虽简单 但稳定实验还需要多次尝试
    电解硫酸铜用以湿法炼铜或是制备稀硫酸,书本上的反应方程式倒是很简单,具体如下:阴极:2Cu2++4e-==2Cu阳极:2H2O-4e-==4H++O2总方程式:2Cu2++2H2O=通电=2Cu+O2+4H+或2CuSO4+2H2O=通电=2Cu+O2+2H2SO4(以上公式来自https://qb.zuoyebang.com/xfe-question/questi......
  • GroovyClassLoader的简单使用
    前言GroovyClassLoader也是Java的一个类加载器实现,它可以将一段源码解析为Class。xxl-job中的GlueFactory就使用了此类加载器来支持GLUE运行模式(任务以源码方式维护在调度中心,支持通过WebIDE在线更新,实时编译和生效,因此不需要指定JobHandler)。使用添加maven依赖<dep......
  • XXL-JOB简单使用
    简介学习简单、轻量级、易扩展、动态生效、调度中心HA、执行器HA、弹性扩容缩容、路由策略、故障转移、阻塞处理策略、任务超时控制、任务失败重试、任务失败告警、分片广播任务、动态分片、事件触发等很多特性。使用下载源码gitee地址项目源码结构如下xxl-job-admin:调度中......
  • 实验1 C语言输入输出和简单程序编写
    实验任务11.1代码1//打印一个字符小人23#include<stdio.h>4intmain()5{6printf("O\n");7printf("<H>\n");8printf("II\n");9printf("O\n");10printf("<H>......
  • destoon 列表页面增加手动选择排序方式
    在mobile/include/mall.inc.php 行60 $order=$MOD['order'];  之前增加排序方式判断如果有order参数则$order接受参数,没有就用默认  $order=$MOD['order'];  1、增加排序以后的mobileurl函数,伪静态规则  ViewCode 伪静态规则 ViewCode  2、模......
  • P2824 [HEOI2016/TJOI2016] 排序
    针对区间排序,显然能够上值域线段树类似,但这里有个更强的做法。如果能转化成01序列,那么一个区间排序的时候,只需区间询问1的个数+区间修改就可以了。因为是排列,很清晰的二分一个mid,把大于等于它的设为1,小于它的设为0,再跑上面的算法,最后check一下询问位置是否为1即可。单调性?感性......
  • 工业互联网-基于OPC 的简单数采系统设计之二
    1、客户端结构客户端主界面Load方法从配置文件中获取产线编号,使用LineBuilder类静态方法Build创建单例引擎,初始化引擎,引擎中创建客户端到服务端连接,包含mesService和opcService,其中opcService是双向通讯。LineBuilder类接着便初始化产线站点,站点属性,站点脚本。LineBuilder类publi......
  • openGauss学习笔记-87 openGauss 数据库管理-内存优化表MOT管理-内存表特性-使用MOT-M
    openGauss学习笔记-87openGauss数据库管理-内存优化表MOT管理-内存表特性-使用MOT-MOT使用简单概述使用MOT非常简单,以下几个小节将会进行描述。openGauss允许应用程序使用MOT和基于标准磁盘的表。MOT适用于最活跃、高竞争和对吞吐量敏感的应用程序表,也可用于所有应用程序的表。......