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

文章目录

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

交换排序

冒泡排序的算法分析:

  • 冒泡排序最好的时间复杂度是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.mzph.cn/news/191294.shtml

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

相关文章

02数仓平台Zookeeper

概述 ZooKeeper是一种分布式协调服务&#xff0c;用于管理大型主机集。在分布式环境中协调和管理服务是一个复杂的过程。ZooKeeper通过其简单的架构和API解决了这个问题。ZooKeeper允许开发人员专注于核心应用程序逻辑&#xff0c;而不必担心应用程序的分布式性质。 Zookeepe…

基于springboot,vue高校图书馆管理系统

开发工具&#xff1a;IDEA 服务器&#xff1a;Tomcat9.0&#xff0c; jdk1.8 项目构建&#xff1a;maven 数据库&#xff1a;mysql5.7 系统分前后台&#xff0c;项目采用前后端分离 前端技术&#xff1a;vueelementUI 服务端技术&#xff1a;springbootmybatisredis 本项…

Kubernetes集群部署—部署Master 节点 (三)

文章目录 1 生成kube-apiserver证书 &#xff08;master节点操作&#xff09;1.1 自签证书颁发机构&#xff08;CA&#xff09;1.2 使用自签CA签发kube-apiserver HTTPS证书 2 从Github下载二进制文件3 解压二进制包 &#xff08;master节点操作&#xff09;4 部署kube-apiserv…

【开源视频联动物联网平台】JAIN-SIP库写一个SIP服务器

JAIN-SIP&#xff08;Java API for Integrated Networks - Session Initiation Protocol&#xff09;是用于实现SIP&#xff08;Session Initiation Protocol&#xff09;的Java API。以下是使用JAIN-SIP库编写一个简单的SIP服务器的基本步骤&#xff1a; 1.添加JAIN-SIP库依赖…

华为OD机试真题-求最多可以派出多少支团队-2023年OD统一考试(C卷)

题目描述: 用数组代表每个人的能力,一个比赛活动要求参赛团队的最低能力值为N,每个团队可以由1人或2人组成,且1个人只能参加1个团队,请计算出最多可以派出多少支符合要求的团队? 输入描述: 5 3 1 5 7 9 8 第一行数组代表总人数,范围[1,500000] 第二行数组代表每个人的能…

[Rust] 快速基础入门教程

Rust 是一个无运行时的强类型语言, 包含很多高级特性, 例如泛型, lambda 等. 又因为其独有的所有权机制, 所以 Rust 的内存安全要比 C 完善许多. 风格 Rust 与 C 族语言不一样, C 族语言在定义方法, 变量时, 都是 类型 关键字 这样的格式, 也就是类型前置. Rust 采用的是类型后…

如何使用Go与MQTT进行通信

简介 本文介绍了如何使用 Go 编程语言与 MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;进行通信。MQTT 是一种轻量级的消息传输协议&#xff0c;广泛应用于物联网和实时通信场景。通过本文的指导&#xff0c;您将学习如何使用 Go 语言创建 MQTT 客户端&am…

MySQL更改用户权限

如果之前已经为一个用户设置了 localhost 作为主机名&#xff0c;并且现在想将其改为 %&#xff08;表示允许该用户从任何主机连接&#xff09;&#xff0c;可以按照以下步骤操作&#xff1a; 登录 MySQL&#xff1a; 首先&#xff0c;使用 root 用户或其他具有管理员权限的用户…

【哈希】字母异位词分组

力扣 class Solution {public List<List<String>> groupAnagrams(String[] strs) {Map<String, List<String>> map new HashMap<>();for (String str : strs) {String hash getHash(str);map.computeIfAbsent(hash, k -> new ArrayList<…

[英语学习][6][Word Power Made Easy]的精读与翻译优化

[序言] 针对第18页的阅读, 进行第二次翻译优化以及纠错, 这次译者的翻译出现的严重问题: 没有考虑时态的变化导致整个翻译跟上下文脱节, 然后又有偷懒的嫌疑, 翻译得很随意. [英文学习的目标] 提升自身的英语水平, 对日后编程技能的提升有很大帮助. 希望大家这次能学到东西,…

PTA:过滤重复整数

题干 本题要求实现一个函数&#xff0c;删去给定整数数组中的重复整数&#xff0c;不重复的元素放于原数组中&#xff0c;不要改变原来的次序。该函数返回不重复的整数个数。 函数接口定义&#xff1a; 函数原型为&#xff1a; int Unique_Int ( int a[ ], int n ); 其中 a[ …

2023年12月03日新闻简报(国内国际)

新闻简报 每天三分钟&#xff0c;朝闻天下事。今天是&#xff1a;2023年12月03日&#xff0c;星期日&#xff0c;农历十月廿一&#xff0c;祝工作愉快&#xff0c;身体健康&#xff0c;生活喜乐&#xff1a; &#x1f449;&#x1f449;国内新闻 1、1日凌晨&#xff0c;四川…

OpenCV技术应用(6)— 暖色滤镜和冷色滤镜

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。本节课就手把手教大家如何将一幅图像转化成暖色滤镜和冷色滤镜&#xff0c;希望大家学习之后能够有所收获~&#xff01;&#x1f308; 目录 &#x1f680;1.技术介绍 &#x1f680;2.暖色滤镜 &#x1f680;3.冷色滤…

SpringBoot 是如何启动一个内置的Tomcat

为什么说Spring Boot框架内置Tomcat 容器,Spring Boot框架又是怎么样去启动Tomcat的?我简单总结下学习过程。 一:简单了解SpringBoot的启动类 我们都知道Spring Boot框架的启动类上是需要使用 @SpringBootApplication 注解标注的, @SpringBootApplication 是一个复合注解…

循环神经网络训练情感分析

文章目录 1 循环神经网络训练情感分析2 完整代码3 代码详解 1 循环神经网络训练情感分析 下面介绍如何使用长短记忆模型&#xff08;LSTM&#xff09;处理情感分类LSTM模型是循环神经网络的一种&#xff0c;按照时间顺序&#xff0c;把信息进行有效的整合&#xff0c;有的信息…

第16章:随堂复习与企业真题(网络编程)

第16章&#xff1a;随堂复习与企业真题&#xff08;网络编程&#xff09; 一、随堂复习 1. 网络编程概述 计算机网络&#xff1a;略网络编程的目的&#xff1a;直接或间接地通过网络协议与其它计算机实现数据交换&#xff0c;进行通讯。需要解决的三个问题&#xff1a; 问题1…

FL Studio(水果软件)2024最新中文版云盘下载

如今&#xff0c;越来越多的音乐人选择使用音乐制作软件来进行音乐的创作&#xff0c;一台电脑、一款软件以及一个外接MIDI就是一个小型的音乐工作站。FL Studio成了音乐界萌新的首选&#xff0c;目前最新的版本为FL Studio2024版本。 你可以不知道如何做音乐&#xff0c;但是…

Normalizing Kalman Filters for Multivariate Time Series Analysis

l l l means latent state&#xff0c;LGM means ‘linear Gaussian state space models’ 辅助信息 作者未提供代码

linux上 more 和 cat 区别

在Linux系统中&#xff0c;​more​和 ​cat​都是用于显示文本文件内容的命令&#xff0c;但它们之间有一些区别。 ​​cat​命令&#xff08;concatenate&#xff09;通常用于以原始形式显示文件的内容&#xff0c;并且会一次性输出整个文件的内容到终端。例如&#xff1a; …

【Python】 Python 中如何实现图片合并及生成长图片文件?

在 Python 中如何实现图片合并及生成长图片文件&#xff1f; 在 Python 中&#xff0c;你可以使用 PIL (Python Imaging Library) 来合并图片。以下是一个简单的示例&#xff0c;展示如何将多个图片文件合并成一个长图片文件&#xff1a; python from PIL import Image # 打开…