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,一经查实,立即删除!

相关文章

【spring】@Bean注解学习

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

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

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

L2-4 寻宝图(Python3)

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

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

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

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

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

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

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

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

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

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

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

Thymeleaf 基本使用

01、Thymeleaf 官网地址&#xff1a;Thymeleafhttps://www.thymeleaf.org/ 简介 Thymeleaf是一种服务器端Java模板引擎&#xff0c;用于将数据渲染为HTML、XML、JavaScript等格式&#xff0c;并在Web浏览器中呈现给用户。 具体来说&#xff0c;Thymeleaf充当着视图层的角色&…

C语言 ——注释

1.1 单行注释 - 语法&#xff1a;// 待注释的内容 - 位置&#xff1a;可放在代码后&#xff0c;称之为行尾注释&#xff1b; 也可放代码上一行&#xff0c;称作行上注释。 c // 这是单行注释文字 1.2 多行注释 - 语法&#xff1a;/* 待注释的内容 */ - 注意&#xff1a;多⾏…

考研C语言复习进阶(1)

目录 1. 数据类型介绍 1.1 类型的基本归类&#xff1a; 2. 整形在内存中的存储 2.1 原码、反码、补码 2.2 大小端介绍 3. 浮点型在内存中的存储 ​编辑 1. 数据类型介绍 前面我们已经学习了基本的内置类型&#xff1a; char //字符数据类型 short //短整型 int /…

前端之用HTML弄一个古诗词

将进酒 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>将进酒</title><h1><big>将进酒</big> 君不见黄河之水天上来</h1><table><tr><td ><img…

借助ChatGPT提高编程效率指南

PS: ChatGPT无限次数&#xff0c;无需魔法&#xff0c;登录即可使用,网页打开下面 一、借助ChatGPT提高编程效率指南 随着计算机技术的飞速发展&#xff0c;编程已经成为了现代社会中一个非常重要的技能。对于许多人来说&#xff0c;编程不仅是一项工作技能&#xff0c;而且是…

操作系统系列学习——操作系统之“树”

文章目录 前言操作系统之“树” 前言 一个本硕双非的小菜鸡&#xff0c;备战24年秋招&#xff0c;计划学习操作系统并完成6.0S81&#xff0c;加油&#xff01; 本文总结自B站【哈工大】操作系统 李治军&#xff08;全32讲&#xff09; 老师课程讲的非常好&#xff0c;感谢 【哈…

sqllab第五关通关笔记

知识点&#xff1a; 报错注入函数语法&#xff08;详见第二关笔记&#xff09;报错注入打印位数最多32位对于大于32位的数据最好使用截取函数进行控制&#xff1b;以保证输出完整mysql表中的重点数据库 information_schema &#xff08;mysql 5.0以上&#xff09; schemata …

每日一题 — 长度最小的子数组

LCR 008. 长度最小的子数组 - 力扣&#xff08;LeetCode&#xff09; 思路&#xff1a; 首先在暴力枚举的方法下&#xff0c;我们可以进行优化&#xff0c;让right不用从头开始&#xff0c;只需让left移动&#xff0c;进行判断。然后就是变成了同向双指针&#xff0c;也就是滑…

责任链模式-C#实现

责任链模式指的是——某个请求需要多个对象进行处理&#xff0c;从而避免请求的发送者和接收之间的耦合关系。 将这些对象连成一条链子&#xff0c;并沿着这条链子传递该请求&#xff0c;直到有对象处理它为止。 主要涉及两个角色&#xff1a; 抽象处理者角色&#xff08;Hand…

【测试开发学习历程】Linux用户管理+文件权限管理

目录 一、用户管理 &#xff08;一&#xff09;用户和用户组的基本概念 1.概念 2.设置原因 3.用户与用户组的关系 4.用户类型 &#xff08;二&#xff09;用户的创建、修改属性和删除用户 1.用户信息文件 2.创建用户 3.修改用户密码 4.修改用户信息 5.用户查询 6.…

MAMP Pro 站点404 Nginx 配置

MAMP Pro 站点配置 if (!-e $request_filename) {rewrite ^(.*)$ /index.php?s/$1 last;break; }

第十四届蓝桥杯C++B组编程题题目以及题解

a.冶炼金属&#xff08;二分&#xff09; 思路&#xff1a; 设任意一条冶炼记录投入金属数量为a,产出金属为b. 对于每一条冶炼记录我们都可以得到 一个转换率V的范围&#xff1a; b<a/v<b1即a/b< v <a/(b1) 为什么是b1呢&#xff1f;因为既然能产出b个金属&#xf…