Java中的插入排序和希尔排序

news2024/9/23 15:25:35

插入排序&&希尔排序

  • 插入排序
  • 希尔排序

上一篇博客我给大家伙说了一下子堆排序,之所以我把插入排序和希尔排序放在一起呢,是因为希尔排序实际上用到了插入排序的思想,希望下面的内容能够帮助到大家.
对于插入排序呢,我们可以参考抓牌顺牌,就在一般情况下,我们也不考虑什么组合技,我们就是按照大小排序的话,是不是抓到一张牌我们就要把这张牌插入到合适的位置呢?是不是牌前面的要比它小,后面的要比它大?

在这里插入图片描述

插入排序

    public void insertSort(int[]arr){
        for(int i=1;i<arr.length;i++){
        //这里从1开始是默认至少有两张牌的,只有一张牌的话无论怎样都是有序的
            int tmp=arr[i];
            int j=i-1;
            for(;j>=0;j--){
            //这里我们敢确保全部走完后一定是有序的是因为,这边是从少部分
            //到大多数的排序,根之前的向下调整建立堆有异曲同工之妙
            //在移动之前我们已经确认前面的元素是有序的了,那么我们就需要
            //找,找一个比要插入牌小的,这样才可以顺理成章地插入
                if(arr[j]>tmp){
                //我们敢做出只要j元素大于i元素就往后移的原因就是
                //我们是从最前面开始排序的,此时前面已经有序,也就是说前面
                //的相对位置不需要改变了
                    arr[j+1]=arr[j];
                }else{
                	//arr[j+1]=tmp;
                	j比i元素小了,所以我们理应把i元素插入到j后面一位
                    break;
                }
            }
            arr[j+1]=tmp;
        }
    }

希尔排序

针对刚才的插入排序,兄弟们有没有发现,最好情况下也就是数据本身就是有序时,时间复杂度应该是O(N)?因为每次以i进入循环时都会break出来,否则就是O(N^2)的时间复杂度,所以当我们数据趋于有序时,使用插入排序理论上是比较快的.
我们的希尔排序正式使用到了这个原理,请看:
此时我们的数组是乱序的,我们就把这个数组分成数组长度组,那么每一组就是一个!对每一组进行插入排序,因为每一组的个数都十分之小,所以宏观上看来,速度也是很快的
在这里插入图片描述
在这里插入图片描述
第二轮我们把数组分成数组长度一半的组数,再对每一组进行插入排序:
在这里插入图片描述
此时此刻每一组内已经有序了,站在整个数组的角度看来,也已经是部分有序,那么我们为什么要大费周折进行跨越式分组呢?
我觉得啊这还是的从宏观上面把握,我也不跟你们细说,我们就抓住一点,是不是现在大的数据已经趋向于数组的后面了?如果是相邻的两个数据进行比较交换的话,换来换去还是局部几个数据在玩!
那么接下来我们组数变一半,数据变两倍继续玩:
在这里插入图片描述
我就不给兄弟们演示了,关键就在于最后那一哆嗦,最后一次我们对整体进行插入排序,那又有人要问了,那为什么不直接使用插入排序呢?因为数据越有序,使用插入排序效果才会越好,我们说过希尔排序本身就是对于插入排序的一种优化.我们来看看代码

    public void shellSort(int []arr){
        int gap=arr.length;
        while(gap>1){
            shell(arr,gap);
            gap=gap/2;
        }
        shell(arr,1);
        //或者
        /./while(gap>1){
        	gap=gap/2;
            shell(arr,gap);
            
        }
        
    	/./
    }

    private void shell(int[]arr,int gap){
        for(int i=1;i<arr.length;i++){
            int j=i-gap;//使用希尔排序时跨度就不再是1了,应该要变成gap
            int tmp=arr[i];
            for(;j>=0;j-=gap){
                if(arr[j]>tmp){
                    arr[j+gap]=arr[j];
                }else{
                    break;
                }
            }
            arr[j+gap]=tmp;
        }
    }

好了,希望我的这篇博客能够帮助到对于插入排序和希尔不太清楚的兄弟们!
百年大道,你我共勉!!!

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

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

相关文章

对象在Eden区分配

一、对象在Eden区分配大多数情况下&#xff0c;对象在新生代中 Eden 区分配。当 Eden 区没有足够空间进行分配时&#xff0c;虚拟机将发起一次Minor GC。在测试之前我们先来看看 Minor GC和Full GC 有什么不同呢&#xff1f;Minor GC/Young GC&#xff1a;指发生新生代的的垃圾…

oracle11g SAP测试机归档日志暴增排查(二)

接上面一的内容&#xff0c;通过logminer可以知道是因为oracle11g设置awr快照引起的插入数据&#xff0c;所以要看这个插入是否正常。 之前也发现SYSAUX表空间也没有多少了&#xff0c;应该这个原因引起产生大量的日志 6、查找SYSAUX表空间满的原因 对于SYSAUX表空间而言&…

【博学谷学习记录】大数据课程-学习第五周总结

Hadoop概述 Hadoop介绍 Hadoop是Apache旗下的一个用java语言实现开源软件框架&#xff0c;是一个开发和运行处理大规模数据的软件平台。允许使用简单的编程模型在大量计算机集群上对大型数据集进行分布式处理。 狭义上说&#xff0c;Hadoop指Apache这款开源框架&#xff0c;它…

Gateway, Zuul, Oauth2.0, 前后端分离, 定制页面,登录回调接口的处理

由于公司与Alexa平台接入了语音控制的功能&#xff0c;需要将公司的账号与Alexa的账号进行绑定&#xff0c;所以需要账号授权的操作&#xff0c;也就是使用授权码模式。开发过程中遇到了很多坑&#xff0c;网上关于前后端分离的定制页面的介绍又很少&#xff0c;前前后后花了一…

泰拉瑞亚灾厄NPC不复活x哥布林军队入侵中断

文章首发及后续更新&#xff1a;https://mwhls.top/4415.html&#xff0c;无图/无目录/格式错误/更多相关请至首发页查看。 新的更新内容请到mwhls.top查看。 欢迎提出任何疑问及批评&#xff0c;非常感谢&#xff01; 目录 NPC 不复活 原因 解决办法 哥布林军队入侵中断 说…

2019-ICML-Towards Graph Pooling by Edge Contraction

2019-ICML-Towards Graph Pooling by Edge Contraction Paper: https://graphreason.github.io/papers/17.pdf Code: https://github.com/Jiajia43/pytorch_geometric 通过边收缩实现图池化 池化层可以使GNN对抽象的节点组而不是单个节点进行推理&#xff0c;从而增加其泛化潜…

MongoDB下载安装

MongoDB 是一个基于分布式文件存储的数据库。由 C 语言编写&#xff0c;旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。 MongoDB 是一个介于关系数据库和非关系数据库之间的产品&#xff0c;是非关系数据库当中功能最丰富&#xff0c;最像关系数据库的。 &#xff08;摘…

音频编辑服务UI SDK接入指导及常见问题

华为 HMS Core 音频编辑服务&#xff08;Audio Editor Kit&#xff09;是华为帮助全球开发者快速构建各类应用音频能力的服务&#xff0c;汇聚了华为在音乐、语音等相关音频领域的先进技术。音频编辑服务为开发者们提供音频基础编辑、AI配音、音源分离、空间渲染、变声、多种音…

IT自动化运维体系的搭建

大家好&#xff0c;我是技福的小咖老师。 对于构建IT运维管理系统而言&#xff0c;如何使用系统的方法来改善运维服务&#xff0c;以及对运维过程进行全面审查尤为重要。今天我们就来讲讲IT自动化运维体系的搭建。 设立IT运维优先原则 优先处理原则是指定义出IT运维的每个关键…

JAVA工具-JDK、JRE、JVM、JIT

目录 概要 JDK和JRE区别 JAVA工具间的联系 JAVA源代码如何被操作系统执行 补充:JIT 概要 JDK&#xff1a;Java Developers Kit-Java开发工具 JRE&#xff1a;Java Runtime Environment-Java运行环境 JVM&#xff1a;Java Virtual Machine-Java虚拟机 JIT&#xff1a;J…

阿里的又一款数据高效同步工具DataX,真香!

我们公司有个项目的数据量高达五千万&#xff0c;但是因为报表那块数据不太准确&#xff0c;业务库和报表库又是跨库操作&#xff0c;所以并不能使用 SQL 来进行同步。当时的打算是通过 mysqldump 或者存储的方式来进行同步&#xff0c;但是尝试后发现这些方案都不切实际&#…

MySQL的回表

核心问题 什么是回表&#xff1f; 答&#xff1a; 回表是一个过程&#xff0c;是获取到主键后再通过主键去查询数据的一个过程就叫回表。 那这个主键从哪来&#xff1f; 从叶子结点存储的内容来&#xff0c;如果存储的是非聚簇索引则通过叶子节点存储的值获取&#xff0c;该值…

机器学习笔记之生成对抗网络(一)逻辑介绍

机器学习笔记之生成对抗网络——逻辑介绍引言生成对抗网络——示例生成对抗网络——数学语言描述生成对抗网络——判别过程描述引言 本节将介绍生成对抗网络的基本逻辑与数学语言描述。 生成对抗网络——示例 生成对抗网络(Generative Adversarial Networks,GAN)&#xff0c…

视觉 → 检测提取

目标检测任务非常有趣且具有挑战性。有些任务非常复杂&#xff0c;需要更多数据才能有所产出。但在这篇文章中&#xff0c;我将展示一个符号检测的小任务&#xff0c;它可以用更少的数据完成。该项目的目的是使用计算机视觉技术从一组给定的图像中提取文本并检测各种符号。在这…

UniApp已经接了手机数据线,但运行工具警告 “没有检查到设备“ (华为手机为例 进行解决)

大部分第一次使用uni进行手机调试都会遇到这个问题 首先 将手机的数据线插入电脑的usb接口是必备前提 然后 就是手机的权限拦截了设备扫描 这就是uni工具找不到设备的原因 接入手机线后 数据会弹出一个USB的提示 点进去之后 我们要设置 允许传输文件 千万别仅充电 接下来的…

Java 以数据流的形式发送数据request Java 数据封装到request中

Java 以数据流的形式发送数据request Java 数据封装到request中 一、描述 1、在做微信支付结果通知的时候&#xff0c;看到一个描述&#xff1a;微信会把相关支付结果及用户信息通过数据流的形式发送给商户 &#xff0c;那么java如何通过数据流的形式发送数据呢&#xff1f; 二…

idea中的Debug工具的使用介绍

文章目录1、设置断点给断点添加条件2、打开DebugDebu启动方式3、Debug功能介绍左侧功能区顶部功能区使用Debug工具时要先进行打断点的操作1、设置断点 断点就是程序运行暂停的位置&#xff0c;在这个位置以后可以根据自己的操作一步一步的执行程序。 idea中设置断点&#xff1…

FreeMarker基础知识

1、总览 官网&#xff1a;http://freemarker.foofun.cn/ 视频地址&#xff1a;https://www.bilibili.com/video/BV1zZ4y1u7iA 2、FreeMarker概述 2.1 FreeMarker概念 FreeMarker 是⼀款 模板引擎&#xff1a; 即⼀种基于模板和要改变的数据&#xff0c; 并⽤来⽣成输出⽂本(…

动态化护眼全新体验,被誉为“护眼神器”的南卡护眼台灯Pro评测出炉

自从家中的孩子上小学后&#xff0c;随着课后作业的逐渐增加&#xff0c;在书房学习时间更长了&#xff0c;由于平时关注到孩子用眼习惯&#xff0c;眼睛有些轻度近视。作为年轻一代的家长&#xff0c;对孩子的用眼健康方面一定要重视&#xff0c;在照明方面&#xff0c;护眼台…

Redis基础篇:Redis简介和安装

第一章&#xff1a;Redis简介 一&#xff1a;简介 Redis诞生于2009年&#xff0c;基于内存的键值型NoSQL数据库。 二&#xff1a;特征 1&#xff1a;键值型&#xff1a;value支持多种不同的数据结构&#xff0c;功能丰富。 2&#xff1a;单线程&#xff1a;单线程执行命令&…