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

文章目录

  • 前言
  • 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.rhkb.cn/news/475472.html

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

相关文章

《Django 5 By Example》阅读笔记:p679-p765

《Django 5 By Example》学习第10天&#xff0c;p679-p765总结&#xff0c;总计87页。 一、技术总结 1.channel 书里通过聊天软件功能演示Django中channel以及异步编程的应用&#xff0c;本人对这块不是很熟悉&#xff0c;不做评价。 2.deployment(部署) services:db:imag…

kali搭建pikachu靶场

前言&#xff1a; 总所周知搭个网站需要有apachemysqlphp&#xff0c;Apache是一个开源的Web服务器软件&#xff0c; MySQL是一种关系型数据库管理系统&#xff08;数据库&#xff09;&#xff0c;PHP是一种在服务器上执行的脚本语言 文章内容来自&#xff1a;【黑帽编程与攻…

C++时间复杂度与空间复杂度

一、时间复杂度&#xff08;Time Complexity&#xff09; 1. 概念 时间复杂度是用来衡量算法运行时间随着输入规模增长而增长的量级。它主要关注的是算法执行基本操作的次数与输入规模之间的关系&#xff0c;而非具体的运行时间&#xff08;因为实际运行时间会受硬件、编程语…

【软考】系统架构设计师-信息安全技术基础

信息安全核心知识点 信息安全5要素&#xff1a;机密性、完整性、可用性、可控性、审查性 信息安全范围&#xff1a;设备安全、数据安全、内容安全、行为安全 网络安全 网络安全的隐患体现在&#xff1a;物理安全性、软件安全漏洞、不兼容使用安全漏洞、选择合适的安全哲理 …

SQL Server Management Studio 的JDBC驱动程序和IDEA 连接

一、数据库准备 &#xff08;一&#xff09;启用 TCP/IP 协议 操作入口 首先&#xff0c;我们要找到 SQL Server 配置管理器&#xff0c;操作路径为&#xff1a;通过 “此电脑” 右键选择 “管理”&#xff0c;在弹出的 “计算机管理” 窗口中&#xff0c;找到 “服务和应用程…

类和对象——static 成员,匿名对象(C++)

1.static成员 a&#xff09;⽤static修饰的成员变量&#xff0c;称之为静态成员变量&#xff0c;静态成员变量⼀定要在类外进行初始化。 b&#xff09;静态成员变量为所有类对象所共享&#xff0c;不属于某个具体的对象&#xff0c;不存在对象中&#xff0c;存放在静态区。 …

游戏引擎学习第17天

视频参考:https://www.bilibili.com/video/BV1LPUpYJEXE/ 回顾上一天的内容 1. 整体目标&#xff1a; 处理键盘输入&#xff1a;将键盘输入的处理逻辑从平台特定的代码中分离出来&#xff0c;放入更独立的函数中以便管理。优化消息循环&#xff1a;确保消息循环能够有效处理 …

【JavaEE初阶 — 多线程】线程池

目录 1. 线程池的原理 1.1 为什么要有线程池 1.2 线程池的构造方法 1.3 线程池的核心参数 1.4 TimeUnit 1.5 工作队列的类型 1.6 工厂设计模式 1.6.1 工厂模式概念 1.6.2 使用工厂模式的好处 1.6.3 使用工厂模式的典型案例 1.6.4 Thread…

基于Vue+SpringBoot的求职招聘平台

平台概述 本平台是一个高效、便捷的人才与职位匹配系统&#xff0c;旨在为求职者与招聘者提供一站式服务。平台内设三大核心角色&#xff1a;求职者、招聘者以及超级管理员&#xff0c;每个角色拥有独特的功能模块&#xff0c;确保用户能够轻松完成从信息获取到最终录用的整个…

黑马点评 秒杀下单出现的问题:服务器异常---java.lang.NullPointerException: null(已解决)

前言&#xff1a; 在此之前找了好多资料&#xff0c;查了很多&#xff0c;都没有找到对应解决的方法&#xff0c;虽然知道是userid为空&#xff0c;但不知道要修改哪里&#xff0c;还是自己的debug能力不足&#xff0c;以后得多加练习。。。 问题如下&#xff1a; 点击限时抢…

使用GDB或Delve对已经运行起来的Go程序进行远程调试

同步发布在我的博客&#xff0c;欢迎来点赞。 使用 GDB 或 Delve 对已经运行起来的 Go 程序进行远程调试 使用 GDB 或 Delve 对已经运行起来的 Go 程序进行远程调试 背景 Java 程序可以很方便地通过 jdwp 参数指定一个对外端口进行远程调试&#xff0c;如 java \ -agentlib…

如何解决pdf.js跨域从url动态加载pdf文档

摘要 当我们想用PDF.js从URL加载文档时&#xff0c;将会因遇到跨域问题而中断&#xff0c;且是因为会触发了PDF.js和浏览器的双重CORS block&#xff0c;这篇文章将会介绍&#xff1a;①如何禁用pdf.js的跨域&#xff1f;②如何绕过浏览器的CORS加载URL文件&#xff1f;②如何使…

Jmeter中的断言(三)

9--MD5Hex断言 功能特点 数据完整性验证&#xff1a;验证响应数据的 MD5 哈希值是否符合预期。简单配置&#xff1a;只需提供预期的 MD5 哈希值即可。灵活配置&#xff1a;可以设置多个断言条件&#xff0c;满足复杂的测试需求。 配置步骤 添加 MD5Hex 断言 右键点击需要添加…

Tomcat和Nginx原理说明

Tomcat Tomcat 是一个开源的 Java 应用服务器&#xff0c;它由多个关键组件组成。这些组件共同协作&#xff0c;实现了 Servlet 容器的功能。以下是 Tomcat 的核心组件说明及其逻辑架构的示意图。 1. Tomcat 核心组件说明 (1) Server 描述&#xff1a;Tomcat 的顶级组件&…

vmWare虚拟环境centos7安装Hadoop 伪分布式实践

背景&#xff1a;近期在研发大数据中台&#xff0c;需要研究Hadoop hive 的各种特性&#xff0c;需要搭建一个Hadoop的虚拟环境&#xff0c;本来想着使用dock &#xff0c;但突然发现docker 公共仓库的镜像 被XX 了&#xff0c;无奈重新使用vm 搭建虚拟机。 大概经历了6个小时完…

10 基于深度学习的目标检测

首次完成时间&#xff1a;2024 年 11月 20 日 1. 使用OpenCV的dnn模块实现图像分类。 1&#xff09;程序代码&#xff1a; import numpy as np import cv2# 解析标签文件 row open("model1/synset_words.txt").read().strip().split("\n") class_label …

ssl证书,以 Nginx 为例

文章目录 1 证书概述1.1 常见证书格式1.2 证书的几种扩展名1.3 关于 PKCS#12 格式 2 Nginx 下证书配置2.1 证书的工作原理2.1.1 单向认证2.1.2 双向认证 2.2 CA 机构签发2.2.1 免费 SSL 证书申请2.2.2 双向认证 2.3 自签证书2.3.1 单向认证2.3.2 双向认证 附录 1&#xff1a;Wi…

android:taskAffinity 对Activity退出时跳转的影响

android:taskAffinity 对Activity跳转的影响 概述taskAffinity 的工作机制taskAffinity对 Activity 跳转的影响一个实际的开发问题总结参考 概述 在 Android 开发中&#xff0c;任务栈&#xff08;Task&#xff09;是一个核心概念。它决定了应用程序的 Activity 如何相互交互以…

专家PID控制

专家PID控制&#xff08;Expert PID Control&#xff09;是一种结合了传统PID控制和专家系统思想的控制方法。它通过引入专家经验、规则和推理机制&#xff0c;以改善PID控制器在面对复杂系统时的性能。专家PID控制不仅仅依赖于固定的PID参数&#xff08;比例、积分、微分&…

ES分词环境实战

文章目录 安装下载1.1 下载镜像1.2 单节点启动 防火墙设置异常处理【1】iptable链路中断 参考文档 参加完2024年11月软考&#xff0c;对ES的分词进行考查&#xff0c;前期有【 Docker 环境下安装部署 Elasticsearch 和 kibana】和【 Docker 环境下为 Elasticsearch 安装IK 分…