C语言 - 堆栈二叉树的基础及应用

1.历史

        堆栈是为了减少程序内存占用的问题而发明的
        机器上电后,所有的变量都需要copy到内存中运行,但是机器的内存大小一直都是比较有限的,所以堆栈和局部变量两个概念被提出来

2.栈

        每次手动创建、删除变量非常麻烦,于是栈被发明出来

3.堆

        逻辑概念上一棵完全二叉树,从左往右依次遍历满的树也叫完全二叉树
        大根堆:在这棵完全二叉树里,每一棵子树的最大值就是头节点的值
        小根堆:。。。

        用malloc 申请的内存块,用free来释放
        用new 申请的内存块,用delete 来释放

4.heap inset

        在堆的最后添加一个节点,然后和父节点比较,如果当前节点大,就交换
        如果父节点大,就停止

        void heap_insert(int arr[], int n)
        {
            while(arr[n] > arr[(n-1)/2])
            {
                swap(arr[n],arr[(n-1)/2]);
                n = (n-1)>>1;
            }
        }

5.heapify(堆化)

        堆中找到最大值,并去掉:找最大最很简单,因为本来就是最大堆;
        关键在于去掉最大值之后,还要形成最大堆:取堆上的最后一个数字,先放在0位置处, 然后比较0位置和其左右节点的大小,谁大就和谁交换位置,然后对后面的节点执行相同操作,
        那什么时候停止呢:左右节点对比父节点的值小时 or 不再有左右节点

        heapify //堆化过程
        void heapify(int arr[],int index,int heapsize)
        {
         //index从哪个位置开始做堆化
         int left = index*2+1;
         while(left<heapsize)
         {
          int max = left+1<heapsize&&arr[left+1] > arr[left] ? left+1 : left;
          max = arr[max] > arr[index] ? max : index;
  
          if(max == index)
           break; 
          swap(arr,max,index);
  
          index = max;
          left = index*2+1;
         }
        }

      

        Heapinsert & heapify 操作时堆操作中最重要的两个操作;

Other:

        全局变量在程序执行的整个周期都存在,需要占用一定的内存空间
        局部变量使用完之后就把它的内存空间释放掉,即这些变量的生存周期只需要和对应的函数相同即可
        另外:由于局部变量在函数中生成,所以函数copy到别的工程里面还能直接用,如果把函数要用到的变量声明在函数外,那么copy的时候就会比较麻烦

应用:

1.最大堆顶节点删除

        将堆最后的节点放在根节点,然后对跟节点进行heapify

        设现有一个数组,数据全部有序,且符合大根堆的排布,问:如果把其中一个数修改,怎么让他恢复成大根堆的排布
        如果修改的这个值比之前大了,那么就对这个值之前的堆进行heapinsert 操作;
        如果修改的这个值比之前小了,那么就对这个值之后的堆进行heapify操作;
        

2.如果完全二叉树一共有N个节点,那么这个树的高度是多少

         Log(N)级别
        时间复杂度也是和log(N)相关

        那么最后的叶节点,基本上会有N/2个数
        倒数第二层叶节点,会有N/4个数
        T(N) = N/2*1 + N/4*2 + N/8*3 + N/16*4 +…
        等式左右两边分别*2 ,然后用2*T(N) - T(N) = T(N) = O(N)时间复杂度

3.堆排序

        给定一个数组,首先0 - 0 范围是堆
        然后保证0 - 2 范围是堆,同时heapsize一直在变大
        使整个数组变成大根堆,然后把最大值和堆上的最后一个值作交换,同时把heapsize--;

        意思是:当最大值来到堆最后的置位后,把它断开联系,因为它已经到了正确的位置,不需要和堆有联系;
        然后对剩下的堆做heapify,调完之后,继续把堆的最大值和最后位置作交换

        //堆排序
        void heapsort(int arr[],int length)
        {
         if(length<2)
          return;
         for(int i=0;i<length;i++)
         {
          heap_insert(arr,i)     //log(N)  
         }
         int heapsize = length;
         swap(arr,0,--heapsize);
         while(heapsize>0)
         {
          heapify(arr,0,heapsize);//log(N) 
          swap(arr,0,--heapsize);  //额外空间复杂度O(1),因为没有申请额外空间
         }
        }

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

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

相关文章

OpenCV-图像基础处理

目录 1 彩色&#xff08;RGB&#xff09;图像 2 灰度图像 3 黑白图像 1 彩色&#xff08;RGB&#xff09;图像 使用cv2.imread()函数加载RGB图像&#xff1b;使用cv2.split()函数分割颜色通道&#xff1b;将BGR颜色格式转换成RGB颜色格式&#xff1b;使用matplotlib或cv2.i…

【spring】@Bean注解学习

Bean介绍 Bean用于指示一个方法应该产生一个Bean对象&#xff0c;并将其交给Spring容器管理。 当使用Bean注解的方法被Spring容器调用时&#xff0c;它只会执行一次&#xff0c;随后该方法返回的Bean对象会被添加到Spring的IOC&#xff08;Inversion of Control&#xff0c;控…

【C#】【SAP2000】读取SAP2000中单元截面信息和几何信息到Grasshopper中

if (build true){// 声明变量int ret;int Numit 0;int[] ObjType new int[0];string[] ObjName new string[0];string sauto "";string propname "";string point1 "";string point2 "";double x1 0;double y1 0;double z1 …

静电ESD整改:原因、影响与解决方案详解?|深圳比创达电子

静电&#xff08;ESD&#xff09;是在日常生活和工作中常见的现象&#xff0c;但它可能对电子设备和器件造成严重的损坏。本文将介绍静电ESD的定义、原因、影响以及解决方案&#xff0c;帮助大家更好地了解ESD问题&#xff0c;并采取相应的整改措施。 一、静电ESD的定义 静电…

计算机网络 应用层的考纲内容 网络应用模型 域名系统

包括&#xff0c; 1&#xff0c;网络应用模型&#xff0c;包括&#xff1a;客户/服务器模型&#xff1b;P2P模型。 2&#xff0c;域名系统DNS&#xff0c;层次域名空间&#xff0c;域名服务器&#xff0c;域名解析过程。 3&#xff0c;文件传输协议&#xff0c;FTP&#xff…

基础的正则表达式

正则表达式&#xff08;Regular Expression&#xff0c;简称正则或RegExp&#xff09;是用于匹配字符串中字符组合的表达式。它是一种强大的工具&#xff0c;可以用于搜索、替换和提取字符串中的文本。 正则表达式由字符和操作符构成&#xff0c;用于描述字符串模式。以下是一些…

LeetCode1.两数之和

LeetCode第一题&#xff0c;两数之和 因为是第一题所以热度比较高&#xff0c;有很多种解法 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应…

L2-4 寻宝图(Python3)

给定一幅地图&#xff0c;其中有水域&#xff0c;有陆地。被水域完全环绕的陆地是岛屿。有些岛屿上埋藏有宝藏&#xff0c;这些有宝藏的点也被标记出来了。本题就请你统计一下&#xff0c;给定的地图上一共有多少岛屿&#xff0c;其中有多少是有宝藏的岛屿。 输入格式&#xf…

Python Excel 文本编辑库之xlsxwriter使用详解

概要 在现代数据处理和报表生成中,Excel 文件是一个非常常见的格式。Python XlsxWriter 库是一个强大的工具,可以帮助开发者轻松创建和编辑 Excel 文件,并且具有高度的灵活性和可定制性。本文将全面介绍 XlsxWriter 库的原理、功能、用法,并通过丰富的示例代码来展示其强大…

什么是工业数采网关?如何远程数采?

随着工业自动化的不断发展&#xff0c;数据采集与远程控制成为了生产过程中不可或缺的一环。而工业数采网关&#xff0c;作为连接工业设备与上位管理系统之间的桥梁&#xff0c;扮演着越来越重要的角色。HiWoo Box 作为一款优秀的工业数采网关产品&#xff0c;为 PLC、传感器、…

AI大语言模型GPT R 生态环境领域数据统计分析

自2022年GPT&#xff08;Generative Pre-trained Transformer&#xff09;大语言模型的发布以来&#xff0c;它以其卓越的自然语言处理能力和广泛的应用潜力&#xff0c;在学术界和工业界掀起了一场革命。在短短一年多的时间里&#xff0c;GPT已经在多个领域展现出其独特的价值…

小脑萎缩患者的饮食秘籍,让生活更加精彩!

在面对小脑萎缩这一挑战时&#xff0c;正确的饮食习惯能够为患者带来巨大的改变。今天&#xff0c;让我们一起探索如何通过饮食的力量&#xff0c;帮助小脑萎缩患者改善生活质量&#xff0c;让每一天都充满希望和活力&#xff01; 小脑萎缩患者的饮食应以均衡为原则&#xff0…

软raid sync_action

控制节点&#xff1a; /sys/block/md127/md/sync_action内核是怎么实现的&#xff0c;为什么mdadm管理命令仅支持四种&#xff1f; [rootgitclient ~]# mdadm --action --help mdadm: action must be one of idle, frozen, check, repair内核文档是怎么描述这个节点&#xff…

比特币如何运作?区块链、网络、交易

文章目录 一、比特币基础知识1.1 什么是比特币&#xff1f;1.2 比特币关键术语解释 二、区块链&#xff1a;比特币的支柱2.1 区块链如何运作2.2 什么是哈希&#xff1f;2.3 采矿的作用2.4 为什么区块链如此重要 三、密码学简介3.1 什么是密码学&#xff1f;3.2 密码学在比特币运…

2024年第十五届蓝桥杯第三期(校内)模拟赛题解

第一题 6 【问题描述】 请问 2023 有多少个约数&#xff1f;即有多少个正整数&#xff0c;使得 2023 是这个正整数的整数倍。 【答案提交】 这是一道结果填空的题&#xff0c;你只需要算出结果后提交即可。本题的结果为一个整数&#xff0c;在提交答案时只填写这个整数&#…

蓝牙系列十五:协议栈GAP层分析

Generic Access Profile&#xff08;通用访问规范&#xff09; 它在用来控制设备连接和广播&#xff0c;用于提供蓝牙设备的通用访问功能&#xff0c;包括设备发现、连接、鉴权、服务发现等等。 GATT是建立连接后通信规范&#xff0c; 而蓝牙是通过GAP建立通信的。 GAP 使你的…

边缘智能融合区块链:研究现状、应用及挑战

源自&#xff1a;信息与控制 作者&#xff1a;任晓旭 仇超 邓辉 戴子明 刘泽军 王晓飞 “人工智能技术与咨询” 发布 摘 要 边缘智能集网络、计算、存储和智能于一体&#xff0c;将智能推向网络边缘&#xff0c;为互联时代的低延迟关键计算开辟了道路。为进一步满足…

算法学习系列(四十):贡献法

目录 引言概念一、孤独的照片二、牛的基因学三、字串分值 引言 关于这个贡献法考的不是很多&#xff0c;主要题型是出现在需要枚举每一个组合这类题&#xff0c;出现的次数较多。没有固定的模板&#xff0c;就是一种思想&#xff0c;跟贪心一样&#xff0c;每个题都是不一样的…

Docker 从容器文件拷贝

从docker容器中拷贝文件到宿主机 docker cp 容器id:容器中文件路径 宿主机拷入路径 docker cp 7e095d9e6f7d:/etc/mysql/mysql.conf.d/mysqld.cnf D:// 从宿主机拷贝文件到docker容器中 docker cp 宿主机拷出路径 容器id:容器中文件路径 docker cp D://mysqld.cnf 7…

最新ChatGPT支持下的PyTorch机器学习与深度学习

近年来&#xff0c;随着AlphaGo、无人驾驶汽车、医学影像智慧辅助诊疗、ImageNet竞赛等热点事件的发生&#xff0c;人工智能迎来了新一轮的发展浪潮。尤其是深度学习技术&#xff0c;在许多行业都取得了颠覆性的成果。另外&#xff0c;近年来&#xff0c;Pytorch深度学习框架受…