十大排序——6.插入排序

news2024/10/5 11:39:44

这篇文章我们来介绍一下插入排序

目录

1.介绍

2.代码实现

3.总结与思考


1.介绍

插入排序的要点如下所示:

首先将数组分为两部分[ 0 ... low-1 ],[ low ... arr.length-1 ],然后,我们假设左边[ 0 ... low-1 ]是已排好序的部分右边[ low ... arr.length-1 ]是未排序的部分,然后每次从未排序的部分取出low位置的元素,插入到已排序区域

过程实例:

初始数据:65,27,59,64,58

     【27,65】59,64,58

     【27,59,65】64,58

     【27,59,64,65】58

              【27,58,59,64,65】

第一次插入:把数组分为[ 65 ]和[ 27,59,64,58 ] 两部分,然后后面一组的第一个元素即27插入到前面一直中,即把27和65进行比较,27<65,把27插入到65前面,此时【27,65】为一个有序列,后面属于无序列

第二次插入:把数组分为[ 27,65 ]和[59,64,58 ] 两部分,然后后面一组的第一个元素即59插入到前面一直中,即把59与65比较,59<65,把59和27比较,59>27,把59插入到27与65之间(后面数据与前面有序列的比较其实就是冒泡排序)

以此类推;

2.代码实现

这次的代码实现分为递归实现和非递归实现两种,供大家参考

package Sorts;

import java.util.Arrays;
//插入排序
public class InsertSort {
    public static void main(String[] args) {
        int [] arr = new int[]{5,9,2,7,3,1,10};
        Insert2(arr);
        System.out.println(Arrays.toString(arr));
    }
    //递归版的方法
    public static void Insert1(int[]arr, int low){
        if (low == arr.length)
            return;
        int t = arr[low];
        int i = low-1;
        //从右向左找插入位置,如果比待插入元素大,则不断右移,空出插入位置
        while (i >= 0 && t <arr[i]){
            arr[i+1] = arr[i];
            i--;
        }
        //找到插入位置
        if (i+1 != low){
            arr[i+1] = t;
        }
        Insert1(arr,low+1);
    }

    public static void Insert2(int[]arr){
        for (int low = 1; low < arr.length-1 ; low++) {
            int t = arr[low];
            int i = low-1;
            //从右向左找插入位置,如果比待插入元素大,则不断右移,空出插入位置
            while (i >= 0 && t <arr[i]){
                arr[i+1] = arr[i];
                i--;
            }
            //找到插入位置
            if (i+1 != low){
                arr[i+1] = t;
            }
        }
    }
}

3.总结与思考

插入排序,一听名字应该就能知道它的逻辑是怎么样的。分两个数组,从无序数组中拿数据往有序数组中插入,并且插入到正确位置。难点就在于怎么插入,这个可以看上面代码的演示。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1601462.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL 8 那些新来的参数,给那些快被淘汰的MYSQL DBA

开头还是介绍一下群&#xff0c;如果感兴趣PolarDB ,MongoDB ,MySQL ,PostgreSQL ,Redis, Oceanbase, Sql Server等有问题&#xff0c;有需求都可以加群群内有各大数据库行业大咖&#xff0c;CTO&#xff0c;可以解决你的问题。加群请联系 liuaustin3 &#xff0c;&#xff08;…

电视盒子哪个好?2024口碑网络电视盒子排行榜

多年来电视盒子始终占据重要地位&#xff0c;功能上并没有受到影响。在这么多品牌中哪些电视盒子的评价是最好的呢&#xff1f;小编根据各大电商平台的用户评价情况整理了口碑最好的网络电视盒子排行榜&#xff0c;跟着小编一起看看市面上的电视盒子哪个好吧。 TOP 1&#xff1…

ChatGPT在遥感领域中的应用

遥感技术主要通过卫星和飞机从远处观察和测量我们的环境&#xff0c;是理解和监测地球物理、化学和生物系统的基石。ChatGPT是由OpenAI开发的最先进的语言模型&#xff0c;在理解和生成人类语言方面表现出了非凡的能力。本课程重点介绍ChatGPT在遥感中的应用&#xff0c;人工智…

MATLAB 点到平面距离的简易计算 (61)

MATLAB 点到平面的垂直距离 (61) 一、算法介绍二、算法实现1.代码2.结果一、算法介绍 一行代码计算点到平面的距离,下面是MATLAB版本的实现方法, 使用一组自定义的点和平面验证,结果表明计算正确: 二、算法实现 1.代码 代码如下(示例): % 定义点的坐标 point = …

Leetcode. 12 整数转罗马数字

罗马数字包含以下七种字符&#xff1a; I&#xff0c; V&#xff0c; X&#xff0c; L&#xff0c;C&#xff0c;D 和 M。 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例…

OpenWrt 多拨负载均衡不起作用

检查 负载均衡->规则->Https->粘滞模式 是否启动&#xff0c;设置为 否 如果设置为是&#xff0c;那么根据官方描述&#xff1a; 来自相同源 IP 的流量&#xff0c;如果已经匹配过此规则并且在粘滞超时时间内&#xff0c;将会使用相同的 WAN 接口 意思就是如果你同一个…

pdf做批注编辑工具 最新pdf reader pro3.3.1.0激活版

PDF Reader Pro是一款功能强大的PDF阅读和编辑工具。它提供了多种工具和功能&#xff0c;帮助用户对PDF文档进行浏览、注释、编辑、转换和签名等操作。以下是PDF Reader Pro的一些主要特色&#xff1a; 最新pdf reader pro3.3.1.0激活版下载 多种查看模式&#xff1a;PDF Reade…

bufbomb level4 kaboom 64位思路

首先&#xff0c;开启地址随机化&#xff0c;观察buf的地址&#xff1a; 注意到bufn的差别巨大&#xff0c;也就是说滑动攻击&#xff08;利用一堆空指令来增加命中率&#xff09;的方法无效。那么只能另寻它路。 在getbufn的ret处打上断点&#xff0c;观察各寄存器的值&…

工业网络交换机的网络容错机制

在工业领域&#xff0c;网络的稳定性和可靠性至关重要。工业网络交换机作为工业网络的核心设备之一&#xff0c;其网络容错机制对于确保工业网络的稳定运行至关重要。本文将深入探讨工业网络交换机的网络容错机制&#xff0c;以及其在保障工业网络稳定性方面的重要作用。 1. 工…

【XR806开发板试用】 VSCode + Samba环境搭建

概览 考虑到开发环境使用linux&#xff0c;对于我这种初学者还不太习惯使用&#xff0c;而且还需要安装虚拟机。个人感觉挺麻烦的&#xff0c;于是我使用以下方案&#xff0c;达到再Windows下使用开发的目的。 主要思路是&#xff1a;使用WSL(Windows Subsystem for Linux)用来…

Nacos的简介及安装和使用

Nacos的简介及安装和使用 1. Nacos简介1.1 核心特性1.2 常见的注册中心1.3 Nacos结构图 2. 如何安装和配置Nacos&#xff1f;2.1 Nacos的安装2.2 如何使用Nacos&#xff1f; 1. Nacos简介 ​ Nacos是一个开源的动态服务发现、配置和服务管理平台&#xff0c;由阿里巴巴开发和维…

【Android GUI】从总体上了解Android的GUI体系

文章目录 概览Android硬件接口HALGralloc与Framebuffer Gralloc模块的加载Gralloc提供的接口Android原生的Gralloc实现打开framebuffer设备打开gralloc设备 参考 概览 Linux内核提供了统一的framebuffer显示驱动。设备节点/dev/graphics/fb*或者/dev/fb*&#xff0c;其中fb0表示…

深入浅出LLM大语言模型

一. 前言 2022年末&#xff0c;聊天程序ChatGPT的上线&#xff0c;在短短5天被注册用户就破百万。ChatGPT的爆火&#xff0c;在一夜之间&#xff0c;带领人类穿越到了真正的人工智能时代。 本文会从ChatGPT作为切入点&#xff0c;在介绍其底层的GPT模型诞生史后&#xff0c;再…

DAY14|二叉树理论基础、递归遍历、迭代遍历、统一迭代

理论基础、递归遍历、迭代遍历、统一迭代 理论基础递归遍历迭代遍历前序中序后序 统一迭代 理论基础 今天的内容极其基础也极其重要&#xff0c;今天的不掌握好&#xff0c;之后一个半月都要坐大牢… 以前算法课上学的还行&#xff0c;可能还能记得一些&#xff08;希望&#…

机器人视觉软件实现目标检测通常借助深度学习技术和计算机视觉算法

机器人视觉软件实现目标检测通常借助深度学习技术和计算机视觉算法。以下是一般而言的目标检测实现步骤&#xff1a; 1、数据收集与标注&#xff1a;首先需要收集包含目标物体的大量图像数据&#xff0c;并对这些图像进行标注&#xff0c;标注出目标物体的位置和类别信息。这些…

深度强化学习(DRL)算法 附录 6 —— NLP 回顾之预训练模型篇

Self-Attention 模型结构 上图架构以 batch_size 为 1&#xff0c;两个时间步的 X 为例子&#xff0c;计算过程如下&#xff1a; 位置编码 根据 self-attention 的模型结构&#xff0c;改变 X 的输入顺序&#xff0c;不影响 attention 的结果&#xff0c;所以还需要引入额外的…

读《AI营销画布》步骤三 扩场景(八)

前言 扩场景写起来有点吃力和干巴&#xff0c;为了文章的连续性&#xff0c;还是写点。 扩场景实际上是需要考虑在第一步和第二步之后是否增加业务流程、节点和场景。在确定增加场景之前&#xff0c;我们需要确保的是第一二步的成功&#xff0c;而且模式是可以复制的。所以&…

【数据分析面试】22.补充缺失数据(Python:数据插值interpolate()用法)

题目 数据集来自一个气候研究组织&#xff0c;列表里带有不同城市每日温度读数的时间序列数据。该数据框有三列&#xff1a;date、city 和 temperature。 由于数据记录问题&#xff0c;某些日期的温度读数可能丢失。该组织需要每天的温度读数&#xff0c;因此他们要求你用线性…

2024中国内燃机展-北京汽车发动机零部件展

2024第二十三届中国国际内燃机与零部件展览会 由中国内燃机工业协会主办、中国机床专用技术设备有限公司、汽车工艺装备成套开发集团协办的2024中国国际内燃机及动力装备博览会&#xff08;简称“动博会”&#xff09;将于2024年10月11日-13日在亦创国际会展中心隆重举办。本届…

linux@内核@内核版本发展@镜像文件查看内核

文章目录 linux内核介绍简介小结 linux发行版和内核各个linux发行版和内核的关系内核更新追踪GAHWE版的内核 内核版本查看&#x1f60a;linux当前系统内核查看未安装时查看网络搜索内核版本号挂载镜像查看虚拟机启动镜像体验版查看内核版本 linux(内核)版本演进&#x1f60a;相…