详解八大排序(一)------(插入排序,选择排序,冒泡排序,希尔排序)

文章目录

  • 前言
  • 1.插入排序(InsertSort)
    • 1.1 核心思路
    • 1.2 实现代码
  • 2.选择排序(SelectSort)
    • 2.1 核心思路
    • 2.2 实现代码
  • 3.冒泡排序(BubbleSort)
    • 3.1 核心思路
    • 3.2 实现代码
  • 4.希尔排序(ShellSort)
    • 4.1 核心思路
    • 4.2 实现代码

前言

在日常生活中,我们常常要将各种各样的数据进行排序,例如我要将班上的学生按照数学成绩从大到小的排序,像这种一般情况,编译器自带的sort函数就能满足我们的要求。但是,假如我要将班上姓刘的学生按照数学成绩从大到小的排序呢?

这种时候,编译器自带的sort函数无法满足需求,我们就需要自己定义一个排序函数。 下面我就要介绍目前的八大排序的原理,代码,以及时间,空间复杂度。

1.插入排序(InsertSort)

1.1 核心思路

直接插入排序的核心思路是先分组,再比较。

数组

例如上面的数组,有六个数。那么我们就可以先把[3,6]分成一组进行比较,得到[3,6]数组。 再把[3,6,7]分成一组进行比较,得到[3,6,7]数组。再把[3,6,7,1]分成一组,得到[1,3,6, 7]数组。 以此类推,得到[1,2,3,4,6,7]数组。

1.2 实现代码

// 插入排序
//插入排序的核心思路就是把i个数分成一组,让第i个数与第i+1个数进行比较
//把较大的数放在后面
void InsertSort(int* arr, int n)
{for (int i = 0; i < n - 1; i++){int end = i;//把i个数分成一组int tmp = arr[end + 1];//记录最后一个数while (end >= 0){//把i + 2个数分成一组,当 end >= 0 时//说明这一组的数没有全部比较,循环比较大小if (arr[end] > tmp){//位于end的数大于最后一个数arr[end + 1] = arr[end];//把位于end的数赋值给end + 1的位置end--;//end--,比较下一个数}else {break;}}arr[end + 1] = tmp;//退出while循环有两种情况//1.end减少到-1,说明这一组的数均大于最后一个数//这样end+1 == 0,把最后一个数赋值给0的位置//2.break提前跳出循环,说明此时end的数小于最后一个数//那么把最后一个数放在end + 1的位置}
}

2.选择排序(SelectSort)

2.1 核心思路

选择排序的核心思路是先找到当前数组中的最大和最小数,再放到相应的位置。

在这里插入图片描述

例如上面的数组,选择排序中我们会定义好第一个位置(0)和最后一个位置(size - 1),再从数组中找到最小(1)和最大数(7),再把1和7放到相应的位置上。 再定义好第二个位置(1)和倒数第二个位置(size - 2),再从数组中找到第二小(2)和 第二大的数(6),再把2和6放到相应的位置上。 以此类推,直到所有的数排序完。

2.2 实现代码

// 选择排序
void SelectSort(int* arr, int n)
{int begin = 0;int end = n - 1;//定义最小数据和最大数据的位置while (begin < end)//当begin小于end时,说明数组中的数据没有比较完,循环比较{int mini = begin, maxi = begin;//先定义一个最小数和最大数for (int i = begin + 1; i <= end; i++)//找大找小,从第二个数开始比较{if (arr[i] > arr[maxi])//当前数组轮到的数大于当前的最大数,那么这个数就是新的最大数{maxi = i;}if (arr[i] < arr[mini])//当前数组轮到的数小于当前的最小数,那么这个数就是新的最小数{mini = i;}}if (maxi == begin)//防止数组中全是相同的数,导致maxi没有改变{maxi = mini;}Swap(&arr[mini], &arr[begin]);//让最小的数与第一个数进行交换Swap(&arr[maxi], &arr[end]);//让最大的数与第二个数进行交换++begin;//已经找到最小的数,需要找第二小的数,所以begin++--end;//已经找到最大的数,需要找第二大的数,所以end--}
}

3.冒泡排序(BubbleSort)

3.1 核心思路

冒泡排序的核心思路是暴力比较,所有的数都比较一遍。

在这里插入图片描述

例如上面的数组,将3与剩下所有的数字比较,3大于1,则把3放在1的位置,1放在3的位置。 所有的数比较完成后就能得到有序的数组。

3.2 实现代码

void BubbleSort(int* arr, int n)
{for (int i = 0; i < n; i++)//找好第一个数{for (int j = i + 1; j < n; j++)//从第二个数开始{if (arr[i] > arr[j])//所有的数与第一个数进行比较{Swap(&arr[i], &arr[j]);//如果第一个数大于比较的数,则交换这两个数}}}
}

4.希尔排序(ShellSort)

4.1 核心思路

希尔排序的核心思路是将数组分成若干个小组,小组先进行预排序,小组预排序完成后,再将 所有的组合并并且进行排序。

在这里插入图片描述

例如上面的数组,将数组分成三分之一,则得到[3,6][7,1][4,2]三个数组。先对这三个数组进行排序,得到[3,6][1,7][2,4]三个数组。 然后将这三个数组合并成两个数组,得到[3,6,1][7,2,4]两个数组。再对[3,6,1][7,2,4]进行排序。得到[1,3,6][2,4,7]两个数组。 再将这两个数组合并,得到[1,3,6,2,4,7],排序得到[1,2,3,4,6,7]。

4.2 实现代码

// 希尔排序
void ShellSort(int* arr, int n)
{int gap = n;while (gap > 1){gap = gap / 3 + 1;//将数组分成三分之一。+ 1 是为了防止gap < 3从而导致gap / 3 == 0//同时for循环结束时,再将数组进行细分for (int i = 0; i < n - gap; i++)//由于数组被分成三分之一个,所以数组的大小也变为三分之一{int end = i;//第一个小组的第一个成员,i++之后就是第二个小组的第一个成员int tmp = arr[end + gap];//第一个小组的最后一个成员,i++之后就是第二个小组的最后一个成员while (end >= 0)//{if (arr[end] > tmp)//当第一个小组里的第一个成员大于最后一个成员时{arr[end + gap] = arr[end];//把第一个成员放到最后一个成员的位置end -= gap;//由于开始比较的是所有组的第一个成员//当end > gap时,说明要开始比较组里的第二个成员了//第二个成员比较完,再比较第三个成员}else {break;}}arr[end + gap] = tmp;//有两种情况//1.end减少到 < 0,说明这一组的数成倒序//则需要把组里所有的数比较并交换完之后结束循环//2.break提前跳出循环//说明此时组里所有比end位置大的数均位于end + gap之后}}
}

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

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

相关文章

如何在 Ubuntu 上使用 Docker 部署 LibreOffice Online

简介 LibreOffice Online&#xff08;也称为Collabora Online&#xff09;是一个开源的在线办公套件&#xff0c;它提供了与LibreOffice桌面版相似的功能&#xff0c;但完全在云端运行。这意味着用户可以通过浏览器访问和编辑文档&#xff0c;而无需在本地计算机上安装任何软件…

【人工智能】PyTorch、TensorFlow 和 Keras 全面解析与对比:深度学习框架的终极指南

文章目录 PyTorch 全面解析2.1 PyTorch 的发展历程2.2 PyTorch 的核心特点2.3 PyTorch 的应用场景 TensorFlow 全面解析3.1 TensorFlow 的发展历程3.2 TensorFlow 的核心特点3.3 TensorFlow 的应用场景 Keras 全面解析4.1 Keras 的发展历程4.2 Keras 的核心特点4.3 Keras 的应用…

macOS 无法安装第三方app,启用任何来源的方法

升级新版本 MacOS 后&#xff0c;安装下载的软件时&#xff0c;不能在 ”安全性与隐私” 中找不到 ”任何来源” 选项。 1. 允许展示任何来源 点击 启动器 (Launchpad) – 其他 (Other) – 终端 (Terminal)&#xff1a; 打开终端后&#xff0c;输入以下代码回车&#xff1a; …

Flutter:RotationTransition旋转动画

配置vsync&#xff0c;需要实现一下with SingleTickerProviderStateMixinclass _MyHomePageState extends State<MyHomePage> with SingleTickerProviderStateMixin{// 定义 AnimationController late AnimationController _controller;overridevoid initState() {super…

同步的意义以及机制

一、同步的意义 同步&#xff08;Synchronization&#xff09;的意义在于确保在多线程环境中&#xff0c;多个线程对共享资源的访问是安全的&#xff0c;避免竞争条件&#xff08;race conditions&#xff09;和数据不一致的情况。 具体来说&#xff0c;同步的核心目标是&…

第二十四章 Spring之源码阅读——AOP篇

Spring源码阅读目录 第一部分——IOC篇 第一章 Spring之最熟悉的陌生人——IOC 第二章 Spring之假如让你来写IOC容器——加载资源篇 第三章 Spring之假如让你来写IOC容器——解析配置文件篇 第四章 Spring之假如让你来写IOC容器——XML配置文件篇 第五章 Spring之假如让你来写…

C++语言之STL

STL STL是标准模板库,是惠普实验室开发的一系列软件的统称 STL的6大组件 容器 算法 迭代器 仿函数 适配器 空间适配器 容器 作用:容纳存储的数据 分类: 序列式容器: 强调值的顺序,每个元素均有固定的位置,除非用删除或插入的操作改变这个位置,如vector,deque/queue,list; 关联式…

嵌入式实验报告:家用计时器

实验目的和要求 1、实验目的 掌握STM32串口通信原理。学习编程实现STM32的UART通信掌握STM32中断程序设计流程。熟悉STM32固件库的基本使用。熟悉STM32定时器中断设计流程。2、实验要求 设计一个家用计时器,其功能如下: 利用串口设置计时时间,格式:XX:XX:X 例如01:59:…

阿里巴巴官方「SpringCloudAlibaba全彩学习手册」限时开源!

最近我在知乎上看过的一个热门回答&#xff1a; 初级 Java 开发面临的最大瓶颈在于&#xff0c;脱离不出自身业务带来的局限。日常工作中大部分时间在增删改查、写写接口、改改 bug&#xff0c;久而久之就会发现&#xff0c;自己的技术水平跟刚工作时相比没什么进步。 所以我们…

低成本搭建单相220V转三相380V变频器配滤波器的转换器

一、单相转三相的迫切需求 在许多工业和商业场景中&#xff0c;三相电源因其高效、稳定的特性而被广泛应用。然而&#xff0c;并非所有场所都能提供三相电源&#xff0c;尤其是在一些老旧建筑或偏远地区&#xff0c;单相220V电源更为常见。这就迫切需要我们找到一种有效的转换…

如何从 VMware 官网下载最新版本的 VMware Workstation

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 下载VMware 📒📝 操作步骤🎈 获取方式 🎈⚓️ 相关链接 ⚓️📖 介绍 📖 你是否曾尝试从 VMware 官网下载 VMware Workstation,但总是被繁杂的选择和复杂的操作困扰?VMware 提供的产品种类繁多,而且官网页面设计复…

数据结构_图的遍历

深度优先搜索遍历 遍历思想 邻接矩阵上的遍历算法 void Map::DFSTraverse() {int i, v;for (i 0; i < MaxLen; i){visited[i] false;}for (i 0; i < Vexnum; i){// 如果顶点未访问&#xff0c;则进行深度优先搜索if (visited[i] false){DFS(i);}}cout << endl…

基于CVE安全公告号,全面修复麒麟ARM系统OpenSSH漏洞

前言&#xff1a;负责的其中一个从0开始搭建的某生产项目上线前需要做青藤安全扫描&#xff0c;过了后才允许上线&#xff0c;该项目从操作系统、中间件、数据库、容器等全国产信创化&#xff0c;公司公告为CVE安全公告号&#xff0c;而修复漏洞的责任归我&#xff0c;需要根据…

python成绩分级 2024年6月python二级真题 青少年编程电子学会编程等级考试python二级真题解析

目录 python成绩分级 一、题目要求 1、编程实现 2、输入输出 二、算法分析 三、程序代码 四、程序说明 五、运行结果 六、考点分析 七、 推荐资料 1、蓝桥杯比赛 2、考级资料 3、其它资料 python成绩分级 2024年6月 python编程等级考试二级编程题 一、题目要求 …

vulnhub靶场-tomato

arp-scan -l用arp-scan探测一下网段内目标靶机的IP arp-scan 是一款轻量级的arp扫描工具&#xff0c;会解析mac地址&#xff0c;就是想 局域网 中所有可能的ip地址发出arp请求包&#xff0c;如果得到arp回应&#xff0c;就证明了局域网中某主机使用了该ip。 nmap扫一下c段 nma…

JavaScript中的执行顺序

分析下面JavaScript代码的执行顺序&#xff1a; <script>setTimeout(() > console.log(代码开始执行), 0)new Promise((resolve, reject) > {console.log(开始for循环);for (let i 0; i < 10000; i) {i 99 && resolve()}}).then(() > console.log(…

【天壤智能-注册安全分析报告-无验证纯IP限制存在误拦截隐患】

前言 由于网站注册入口容易被机器执行自动化程序攻击&#xff0c;存在如下风险&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露&#xff0c;不符合国家等级保护的要求。短信盗刷带来的拒绝服务风险 &#xff0c;造成用户无法登陆、注册&#xff0c;大量收到垃圾短信的…

大数据实验4-HBase

一、实验目的 阐述HBase在Hadoop体系结构中的角色&#xff1b;能够掌握HBase的安装和配置方法熟练使用HBase操作常用的Shell命令&#xff1b; 二、实验要求 学习HBase的安装步骤&#xff0c;并掌握HBase的基本操作命令的使用&#xff1b; 三、实验平台 操作系统&#xff1…

内网安全隧道搭建-ngrok-frp-nps-sapp

1.ngrok 建立内网主机与公网跳板机的连接&#xff1a; 内网主机为客户机&#xff1a; 下载客户端执行 2.frp &#xff08;1&#xff09;以下为内网穿透端口转发 frp服务端配置&#xff1a; bindPort 为frp运行端口 服务端运行 ./frps -c frps.ini frp客户端配置&#xf…

三十一、构建完善微服务——API 网关

一、API 网关基础 系统拆分为微服务后&#xff0c;内部的微服务之间是互联互通的&#xff0c;相互之间的访问都是点对点的。如果外部系统想调用系统的某个功能&#xff0c;也采取点对点的方式&#xff0c;则外部系统会非常“头大”。因为在外部系统看来&#xff0c;它不需要也没…