数据结构第九天(堆排序)

目录

前言

概述

源码:

主函数:

运行结果:

其他



前言

哈哈,这个堆排序算法很久之前就已经敲过一遍了,时间一久,思路有点淡忘。今天重新看过一遍之后,又亲自撸代码,幸运的是,代码运行一次就成功了,没有任何逻辑错误而且结果也达到了预期效果。

在最后,与大家共勉:你所走的每一步路,都算数。

概述

堆排序(Heap Sort)是一种基于比较的排序算法,使用二叉堆(Binary Heap)数据结构来帮助实现其排序过程。二叉堆可以被视为一颗完全二叉树,其中每个节点的值都不大于(或不小于)其子节点的值,这样的二叉堆分别称为最大堆(Max Heap)和最小堆(Min Heap)。堆排序主要包括两个步骤:建堆(构造初始堆)和调整堆。

1. 建堆(构造初始堆)

首先,将待排序的序列构造成一个最大堆,即所有父节点的值都大于或等于子节点的值。这一步的目的是选出最大的元素(位于根节点),准备将它与序列的末尾元素交换。

建堆的过程从最后一个非叶子节点开始,向前逐个对每个父节点进行调整,确保每个父节点的值都大于其子节点的值。最后一个非叶子节点的位置可以通过序列长度计算得出,设序列长度为n,则最后一个非叶子节点的位置是n/2 - 1(假定序列的起始索引为0)。

2. 调整堆

将最大堆的根节点(即当前最大值)与最后一个元素交换,然后减少堆的大小,对新的根节点执行下沉操作,以重新满足最大堆的性质。重复这个过程,直到堆的大小为1,排序完成。

下沉操作指的是将新的根节点值与其子节点中较大者交换,直到该节点值大于其子节点或已经到达叶子节点。

堆排序的算法步骤

  1. 建立最大堆:从最后一个非叶子节点开始,向上进行调整,确保每个父节点都大于其子节点。
  2. 排序
    • 将根节点(最大值)与最后一个元素交换,此时序列的最后部分已经是排序好的。
    • 减少堆的大小(排除已排序的部分),对新的根节点进行下沉操作,以维护最大堆的性质。
    • 重复上述过程,直到堆的大小为1。

时间复杂度

  • 最好、最坏、平均情况下的时间复杂度均为O(n log n)。
  • 堆排序的空间复杂度为O(1),因为它是原地排序算法。

特点

  • 不稳定排序:相同的元素可能会因为堆调整过程而改变其相对位置。
  • 原地排序:不需要额外的存储空间。

堆排序是一种高效的排序算法,尤其适用于数据量大的情况。由于其在最坏情况下也能保持O(n log n)的时间复杂度,因此是一种非常可靠的排序方法。

源码:

void heapAdjust(int* dest,  unsigned int dataCnt)
{unsigned int head = dataCnt;head /= 2;if (head * 2 + 1 == dataCnt){if (*(dest + head * 2) > *(dest + head * 2 - 1)){if (*(dest + head - 1) > *(dest + head * 2 - 1)){swap(*(dest + head - 1), *(dest + head * 2 - 1));}}else if (*(dest + head - 1) > *(dest + head * 2)){swap(*(dest + head - 1), *(dest + head * 2));}}else{if (*(dest + head -1) > *(dest + head * 2 - 1)){swap(*(dest + head - 1), *(dest + head * 2-1));}}for (int i = dataCnt/2-1; i > 0; --i){head = i;if (*(dest + head * 2) > *(dest + head * 2 - 1)){if (*(dest + head - 1) > *(dest + head * 2 - 1)){swap(*(dest + head - 1), *(dest + head * 2 - 1));}}else if (*(dest + head - 1) > *(dest + head * 2)){swap(*(dest + head - 1), *(dest + head * 2));}}}
void sortByHeapSort(int* dest, const unsigned int dataCnt)
{for (int i = 0; i < dataCnt; ++i){heapAdjust(dest + i, dataCnt - i);}
}

主函数:

#include<stdio.h>
#include<iostream>
using namespace std;
#include"dataStructAPI.h"
#include"sort.h"
#include<windows.h>
int main()
{

int array[16] = { 0 };
    numberProducer.getFilledArray(array,16);
    cout << "  原 始 数 据   :";
    numberProducer.showArray(array,16);


    sortByHeapSort(array, 16);
    cout << "   堆 排 序 后  :";
    numberProducer.showArray(array, 16);


    sortBySelectSort(array, 16);
    cout << "选 择 排 序 后  :";
    numberProducer.showArray(array, 16);

    sortByQuickSort(array, 16);
    cout << "快 速 排 序 后  :";
    numberProducer.showArray(array, 16);

    sortByBubbleSort(array, 16);
    cout << "冒 泡 排 序 后  :";
    numberProducer.showArray(array, 16);

    sortByShellInsert(array, 16, 3);
    cout << "希尔插入排序后  :";
    numberProducer.showArray(array, 16);

    sortByBinarySearchInsert(array, 16);
    cout << "折半插入排序后  :";
    numberProducer.showArray(array, 16);

    sortByDirectInsert(array, 16);
    cout << "直接插入排序后  :";
    numberProducer.showArray(array, 16);
    
    system("pause");
    return 0;
}

运行结果:

其他

数据结构第一天(生成1000以内的随机数自动填充数组)

数据结构第二天(直接插入排序/内存申请/指针操作)

数据结构第三天(折半插入排序)

数据结构第四天(希尔排序)

数据结构第五天(冒泡排序)

数据结构第六天(快速排序)

数据结构第七天(简单选择排序)

数据结构第八天(归并排序)

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

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

相关文章

联合索引之最左匹配原则

一、定义&#xff1a; 联合索引中&#xff0c;从最左边的字段开始匹配&#xff0c;若条件中字段在联合索引中符合从左到右的顺序则走索引&#xff0c;否则不走&#xff0c;可以简单理解为(a, b, c)的联合索引相当于创建了a索引、(a, b)索引和(a, b, c)索引。同时遇到范围查询&…

设计模式(行为型模式)责任链模式

目录 一、简介二、责任链模式2.1、处理器接口2.2、具体处理器类2.3、使用 三、优点与缺点 一、简介 责任链模式&#xff08;Chain of Responsibility Pattern&#xff09;是一种行为设计模式&#xff0c;允许你将请求沿着处理者链进行传递&#xff0c;直到有一个处理者能够处理…

【MATLAB源码-第137期】基于matlab的NOMA系统和OFDMA系统对比仿真。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 NOMA&#xff08;非正交多址&#xff09;和OFDMA&#xff08;正交频分多址&#xff09;是两种流行的无线通信技术&#xff0c;广泛应用于现代移动通信系统中&#xff0c;如4G、5G和未来的6G网络。它们的设计目标是提高频谱效…

如何使用C#调用LabVIEW算法

新建一个工程 这是必须的&#xff1b; 创建项目 项目 点击完成&#xff1b; 将项目另存为&#xff1b;方便后续的使用&#xff1b; 创建 一个测试VI 功能很简单&#xff0c;用的一个加法&#xff1b;将加数A&#xff0c;B设置为输入&#xff0c;和C设置为输出&#xff0c;…

正点原子--STM32通用定时器学习笔记(2)

1. 通用定时器输入捕获部分框图介绍 捕获/比较通道的输入部分&#xff08;通道1&#xff09; 输入通道映射CC1S[1:0]→采样频率CKD[1:0]→滤波方式IC1F[3:0]→边沿检测方式CC1P→捕获分频ICPS[1:0]→使能捕获CC1E 输入部分对相应的TIx输入信号采样&#xff0c;并产生一个滤波后…

MPLS——多协议标签交换

目录 1 多协议标签交换 MPLS 1.1 MPLS 的工作原理 1.1.1 MPLS 工作特点 1.1.2 MPLS 协议的基本原理 1.1.3 MPLS 的基本工作过程 1.2 转发等价类 FEC 1.2.1 FEC 用于负载平衡 1.3 MPLS 首部的位置与格式 1.3.1 MPLS 首部的位置 1.3.2 MPLS 首部的格式 1.4 新一代的…

STM32 HAL NTC(3950 10k)查表法

NTC&#xff08;Negative Temperature Coefficient&#xff09;是指随温度上升电阻呈指数关系减小、具有负温度系数的热敏电阻现象和材料。该材料是利用锰、铜、硅、钴、铁、镍、锌等两种或两种以上的金属氧化物进行充分混合、成型、烧结等工艺而成的半导体陶瓷&#xff0c;可制…

vue项目开发vscode配置

配置代码片段 步骤如下&#xff1a; 文件->首选项->配置用户代码片段新增全局代码片段起全局代码片段文件名“xxx.code-snippets” 这里以配置vue2初始代码片段为例&#xff0c;配置具体代码片段 {"name": "vue-sph","version": "…

modelsim仿真使用到vivado的IP,该如何使用!

modelsim仿真时&#xff0c;如果使用到了vivado的IP就会报错&#xff0c;本次就告诉大家如何将vivado的IP添加到modelsim中直接仿真。 一、生成ini文件以及IP打包 打开vivado&#xff0c;点击上方的Tools-->Compile Simulation Libraries得到如下界面 simulator&#xff1…

【Python基础】案例分析:泰坦尼克分析

泰坦尼克分析 1 目的&#xff1a; 熟悉数据集熟悉seaborn各种操作作 import pandas as pd import seaborn as sns import numpy as np import matplotlib.pyplot as plt %matplotlib inline home rdata df sns.load_dataset(titanic, data_homehome) df.head()survivedpcl…

#P12365. 相逢是首歌

Description monkey A与monkey B住在一颗树上&#xff0c;每天他们都会相约一起出去玩。 q次询问&#xff0c;每次询问给两个点x和y&#xff0c;代表他们各自的出发点&#xff0c;他们以相同的速度&#xff0c;沿着二者的最短路前进. 问二者会在点上相遇&#xff0c;还是在边…

mmdetection使用自己的voc数据集训练模型实战

一.自己数据集整理 将labelimg格式数据集进行整理 1.1. 更换图片后缀为jpg import os import shutilroot_path/media/ai-developer/imgfileos.listdir(root_path)for img in file:if img.endswith(jpeg) or img.endswith(JPG) or img.endswith(png):img_pathos.path.join(root…

理想汽车学华为,年终奖红包有点大(含算法原题)

理想年终奖红包 2月5日&#xff0c;有微博用户发帖称&#xff0c;脉脉上看到&#xff0c;今年理想汽车的年终奖红包有点大。 对此&#xff0c;李想转发并评论&#xff1a; ❝ 不能只学华为的流程&#xff0c;而不学华为的利益分配。奖罚不分明&#xff0c;是组织低效的最大原因…

C++ lambda [],[=] ,[],[this] 的使用

在c11标准中引入了lambda表达式&#xff0c;一般用于定义匿名函数 [],[] ,[&],[this] 都是捕获列表 [] 的作用&#xff1a; 什么也不捕获 [] 的作用&#xff1a; 按值捕获所有变量 [&] 的作用&#xff1a; 引用捕获所有外部作用域内的变量 [this]的作用&#xf…

怎么理解 Redis 事务

背景 在面试中经常会被问到&#xff0c;redis支持事务吗&#xff1f;事务是怎么实现的&#xff1f;事务会回滚吗&#xff1f;又是一键三连&#xff0c;我下面分析下&#xff0c;看看能不能吊打面试官 什么是Redis事务 事务是一个单独的隔离操作&#xff1a;事务中的所有命令…

【SpinalHDL】1. Getting Started

1. Getting Started 1.1 SpinalHDL开发环境的搭建 开发环境的搭建参考SpinalHDL 开发环境搭建一步到位&#xff08;图文版&#xff09; - 极术社区 - 连接开发者与智能计算生态就可以了&#xff0c;so detail. 重点在于sbt切换为国内源&#xff0c;可以参考如下链接Windows上…

企业为什么选择SASE?香港电讯专家给你答案!

2019年&#xff0c;Gartner发布了全新的网络安全模型&#xff1a;安全访问服务边缘&#xff08;Secure Access Service Edge, SASE&#xff09;&#xff0c;并预测到2025年80%的企业将使用SASE/SSE架构统一网络、云服务和私人应用程序的安全访问。那么企业为什么选择SASE&#…

Web课程学习笔记--CSS-Position学习

CSS Position学习 CSS Position有四个属性&#xff1a; relativeabsolutefixedstatic&#xff08;默认&#xff09; 样例 <div id"parent"><div id"sub1">sub1</div><div id"sub2">sub2</div> </div>su…

Git合并多个commit

git rebase -i commitId 假设想要合并最后3个commit&#xff0c; git log显示 commit id 1 commit id 2 commit id 3 commit id 4 则执行git rebase -i commitId4. 注意是4&#xff0c;不是3. 然后&#xff0c;pick最老的commit (commit id 3). https://blog.csdn.net/qiao…

企业计算机服务器中了mallox勒索病毒怎么办,mallox勒索病毒处理流程

由于网络技术的不断发展与应用&#xff0c;越来越多的企业开始依赖计算机技术来提高企业效率。然而&#xff0c;网络安全威胁无处不在&#xff0c;严重影响着企业计算机服务器中的数据安全。近期&#xff0c;云天数据恢复中心接到许多中大型企业的求助&#xff0c;企业的多台服…