【交换排序 简单选择排序 堆排序 归并排序】

news2024/11/19 15:26:07

文章目录

  • 交换排序
  • 简单选择排序
  • 堆排序
  • 归并排序

交换排序

冒泡排序的算法分析:

  • 冒泡排序最好的时间复杂度是O(n)
  • 冒泡排序最好的时间复杂度是O(n平方)
  • 冒泡排序平均时间复杂度为O(n的平方)
  • 冒泡排序算法中增加一个辅助空间temp,辅助空间为S(n)=O(1)。
  • 冒泡排序是稳定的。
void bubble_sort(int arr[],int n);
void printArr(int arr[]);

#define MAXSIZE 20	//设记录的值不超过20个
#define  KeyType int//设关键字为整型量
#define InfoType int //定义InfoType的其他数据项


typedef struct {
	KeyType key;//定义每个记录(数据元素)的结构
	InfoType otherinfo;//其他数据项
}RedType;

typedef struct SqList {
	RedType r[MAXSIZE + 1];//存储顺序表的结构
	//r[0]一般做哨兵或者缓冲区
	int length;//顺序表的长度
}SqList;




//void bubble_sort(SqList& L) {
//	//使用flag作为是否有交换的标记
//	int i,n,i,j;
//	int flag = 1;
//	RedType x;
//	for (i = 1; i <= n - 1 && flag == 1; i++) {
//		flag = 0;
//		for (j = 1; j <= i; j++) {
//			if (arr[] > L.r[j + 1][]) {
//				//发生逆序
//				flag = 1;//发生交换,flag置为1,若本趟没发生交换,flag保持为0.
//				x = arr;
//				arr = L.r[j + 1];
//				L.r[j + 1] = x;
//			}
//		}
//	}
//}

void bubble_sort(int arr[],int n) {
	//使用flag作为是否有交换的标记
	int i, j;
	int flag = 1;
	int x;
	for (i = 1; i <= n - 1 && flag == 1; i++) {
		flag = 0;
		for (j = 1; j <= i; j++) {
			if (arr[j] > arr[j + 1]) {
				//发生逆序
				flag = 1;//发生交换,flag置为1,若本趟没发生交换,flag保持为0.
				x = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = x;
			}
			printf("第%d趟 ", i);
		}
		
	}
}

简单选择排序

选择最小的值,进行排序。
在这里插入图片描述

堆排序

堆的定义:
若n个元素的序列{a1,a2…an}满足
在这里插入图片描述则该序列分为小根堆大根堆
从堆的定义可以看出,堆实质是满足如下性质的完全二叉树,二叉树中任一非叶子节点均小于(大于)他的孩子结点。
在这里插入图片描述
堆排序:
若在输出堆顶的最小值(最大值)后,使得剩余n-1个元素的序列重新又建成一个堆,则得到n个元素的次小值(次大值)…如此反复,则有能得到一个有序序列,这个过程称之为堆排序。

实现堆排序需解决的两个问题:

  1. 如何由一个无序序列建成一个堆?
    单结点的二叉树是堆;
    在完全二叉树中所有以叶子结点(序号为i>n/2)为根的子树是堆。
    由于堆实质上是一个线性表,那么我们可以顺序存储一个堆。
    在这里插入图片描述
    步骤:
    从最后一个非叶子结点开始向前调整:
    ①调整从第n/2个元素开始,将以该元素为根的二叉树调整为堆。
    ②将以序号n/2-1的结点为根的二叉树调整为堆;
    ③将以序号n/2-2的结点为根的二叉树调整为堆;
    ④将以序号n/2-3的结点为根的二叉树调整为堆;
    在这里插入图片描述

  2. 如何输出堆顶元素后,调整剩余元素为一个新的堆?
    小根堆:
    1.输出堆顶元素之后,以堆中最后一个元素替代之
    在这里插入图片描述

2.然后将根结点值与左右子树的根结点值进行比较,并与其中小者进行交换
在这里插入图片描述
在这里插入图片描述

3.重复上述操作,直至叶子结点,将得到新的堆,称这个从堆顶至叶子的调整过程为“筛选”。
在这里插入图片描述
下一次再输出堆顶元素27,再将最后一个元素97向上调整。再选左,右子树较小的那一个就是38,再将38调上去,再比较左右子树的大小。

算法性能分析:
在这里插入图片描述

归并排序

基本思想:将两个或两个以上的有序子序列“归并”成一个。
例:二路归并,归并树。
![

  • [ ]

  • 在这里插入图片描述

](https://img-blog.csdnimg.cn/direct/14c3d5b0f8d24c278f889998ec61ac28.png)

在这里插入图片描述

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

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

相关文章

1-6、编程语言排行榜

语雀原文链接 https://www.tiobe.com/tiobe-index/

基于Vue框架的电子商城购物平台小程序的设计与开发

基于JavaWebSSMVue电子商城购物平台小程序系统的设计和实现 源码获取入口KaiTi 报告/Ren务书Lun文目录前言主要技术系统设计功能截图订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码获取入口 KaiTi 报告/Ren务书 一、选题的目的和意义 自从微信推出了微信小程序…

如何自动筛选高质量的指令微调数据喂给大模型?

前言 大家都知道在大模型时代&#xff0c;数据有多么重要&#xff0c;质量多高都不过分&#xff01;甚至直接决定着最终的效果。 尤其做SFT&#xff0c;模型框架基本不用改&#xff08;事实上也改不动&#xff09;&#xff0c;如何做一份符合自己场景高质量的SFT数据成了唯一…

C++中STL的容器vector

文章目录 什么是vectorvector与普通顺序表不同的点 vector的成员函数operatoroperator[]begin与end与iteratorsize()capacityresizeemptyreservepush_backpop_backinserteraseswapclear成员变量 总结 什么是vector vector&#xff1a;是数据结构里面的顺序表&#xff0c;开辟一…

【MATLAB】基于EMD分解的信号去噪算法(基础版)

代码操作 【MATLAB】基于EMD分解的信号去噪算法&#xff08;基础版&#xff09; 代码的主要内容 基于EMD&#xff08;经验模态分解&#xff09;的信号去噪算法通常可以结合相关系数、信号的熵值或者方差贡献率来完成去噪处理。这些指标可以用于确定阈值&#xff0c;从而对信号…

WPF仿网易云搭建笔记(2):组件化开发

文章目录 前言专栏和Gitee仓库依赖属性实战&#xff1a;缩小&#xff0c;全屏&#xff0c;关闭按钮依赖属性操作封装主窗口传递this本身给TitleView标题控件主要代码MainWindow.xmalMainWindow.cs依赖属性方法封装TitleView.csTitleViewModelTitleViewModel实现效果 前言 这次…

FreeRTOS的内存管理方法(超详细)

内存管理 我们知道每次创建任务、队列、互斥锁、软件定时器、信号量或事件组时&#xff0c;RTOS 内核都需要 RAM &#xff0c; RAM 可以从 RTOS API 对象创建函数内的 RTOS 堆自动动态分配&#xff0c; 或者由应用程序编写者提供。 如果 RTOS 对象是动态创建的&#xff0c;那么…

Mac虚拟机CrossOver23破解版下载和许可证下载

CrossOver Mac Mac 和 Windows 系统之间的兼容工具。使 Mac 操作系统的用户可以运行 Windows 系统的应用&#xff0c;从办公软件、实用工具、游戏到设计软件&#xff0c; 您都可以在 Mac 程序和 Windows 程序之间随意切换。 系统要求 运行macOS的基于Intel或Apple Silicon 的…

99、NeRF ray space

CG相机模型 在图形学中最常用的相机模型的原理和小孔成像是类似的。 不同之处在于&#xff0c;如上图&#xff0c;小孔成像得到的图像是倒立的&#xff0c;但是我们希望得到的图像是正向的&#xff0c;因此&#xff0c;我们选择小孔前成像。 从 3D 到 2D 的投影&#xff0c;…

笔迹鉴定系统

用于笔迹鉴定书的生成。对于检材进行的特征采集&#xff0c;将采集到的特征自动排版&#xff0c;生成比对表&#xff0c;然后在比对表上进行标注。主要标注有&#xff1a;写法、笔顺、箭头、实线、虚线、左括号、右括号、上括号、下括号、运笔、注释、来源、折线、测量、矩形、…

iptables——建立linux安全体系

目录 一. 安全技术类型 二. linux防火墙 1. 按保护范围划分&#xff1a; 2. 按实现方式划分&#xff1a; 3. 按网络协议划分&#xff1a; 4. 防火墙原理 三. 防火墙工具——iptables 1. netfilter 中五个勾子函数和报文流向 数据包传输过程&#xff1a; ① .五表四链…

【2023传智杯-新增场次】第六届传智杯程序设计挑战赛AB组-DEF题复盘解题分析详解【JavaPythonC++解题笔记】

本文仅为【2023传智杯-第二场】第六届传智杯程序设计挑战赛-题目解题分析详解的解题个人笔记,个人解题分析记录。 本文包含:第六届传智杯程序设计挑战赛题目、解题思路分析、解题代码、解题代码详解 文章目录 一.前言二.赛题题目D题题目-E题题目-F题题目-二.赛题题解D题题解-…

个人博客网站如何实现https重定向(301)到http

对于个人网站站注册比较少的&#xff0c;服务器配置不是很好的&#xff0c;没必要https,https跳转到http是要时间的&#xff0c;会影响网站打开的速度。免费的https每年都要更换。个人博客网站https有一段时间了&#xff0c;而且很多页面都有收录排名&#xff0c;现在已去掉htt…

redis中使用事务保护数据完整性

事务是指一个执行过程&#xff0c;要么全部执行成功&#xff0c;要么失败什么都不改变。不会存在一部分成功一部分失败的情况&#xff0c;也就是事务的ACID四大特性&#xff08;原子性、一致性、隔离性、持久性&#xff09;。但是redis中的事务并不是严格意义上的事务&#xff…

Eclipse 4.30 正式发布 来看看有哪些值得期待的新特性

Eclipse 4.30 已正式发布&#xff0c;主要特性如下&#xff1a; 1、支持新的 Java 语言特性&#xff1a;包括 JEP 440: Record Patterns 和 JEP 441: Pattern Matching for Switch 2、针对 Java 编辑器的快速修复功能&#xff1a;包括添加默认 case、移除默认 case 和插入 br…

VGG模型

概念&#xff1a; CNN感受野 在卷积神经网络中&#xff0c;决定某一层输出结果中的一个元素所对应的输入层的区域大小&#xff0c;被称作感受野&#xff08;receptive field&#xff09;。通俗的解释是&#xff0c;输出feature map上的一个单元对应输入层上的区域大小。 VGG…

IntelliJ IDEA创建一个Maven项目

在IDEA中创建Maven项目&#xff0c;前提是已经安装配置好Maven环境 。 本文主要使用的是IntelliJ IDEA 2022.2.1 (Community Edition) 1.创建一个新project:File>Project 2.修改Maven配置&#xff1a;File>Settings>搜索maven 创建好的工程如下&#xff1a; src/main…

[ 蓝桥杯Web真题 ]-组课神器

目录 介绍 准备 目标 规定 思路 参考解法 介绍 在很多教育网站的平台上&#xff0c;课程的章节目录会使用树型组件呈现&#xff0c;为了方便调整菜单&#xff0c;前端工程师会为其赋予拖拽功能。本题需要在已提供的基础项目中&#xff0c;完成可拖拽树型组件的功能。 准…

【数据结构】——排序篇(上)

前言&#xff1a;前面我们已经学过了许许多多的排序方法&#xff0c;如冒泡排序&#xff0c;选择排序&#xff0c;堆排序等等&#xff0c;那么我们就来将排序的方法总结一下。 我们的排序方法包括以下几种&#xff0c;而快速排序和归并排序我们后面进行详细的讲解。 直接插入…

【SpringBoot】解析Springboot事件机制,事件发布和监听

解析Springboot事件机制&#xff0c;事件发布和监听 一、Spring的事件是什么二、使用步骤2.1 依赖处理2.2 定义事件实体类2.3 定义事件监听类2.4 事件发布 三、异步调用3.1 启用异步调用3.2 监听器方法上添加 Async 注解 一、Spring的事件是什么 Spring的事件监听&#xff08;…