数据结构---堆栈和列

一、堆栈

1.栈堆:具有一定操作约束的线性表;(只在一端做插入删除)

2.栈的顺序存储结构:

由一个一维数组和一个记录栈顶元素位置的变量组成。定义方式如下:

3.入栈操作:

注意:(1)top表示栈顶元素的下标,maxsize表示数组容量;

(2)要放入栈顶的上面,同时top加1;

4.出栈操作:

注意:(1)栈堆初始化时top为-1,即数组首元素之前的那个位置的下标;

5.一个数组实现两个堆栈:

堆栈初始化:

注意:top2代表数组最后一个元素之后位置的下标;

对两个堆栈的区别方法:引入标识tag:

出栈操作:(记得先检验是否为空)

6.堆栈的链式存储:

栈的链式存储结构实际上就是一个单链表,叫做链栈。插入和删除操作只能在链栈的栈顶进行。

(1)创建堆栈结构:

(2)创建堆栈:

(3)判断是否为空:

(4)入栈操作:

注意:最后才对s->next做处理;

(5)出栈操作:

注意:第一个赋值语句,是让firstcell指向s->next指向的位置,所以firstcell指向的是要删除的结点;

7.中缀转换为后缀:

8.堆栈的应用:

主要应用的是堆栈的特性:先来先用,后来后用;

二、队列

1.队列的顺序存储实现:

队列的顺序存储结构通常由一个一维数组和一个记录队列头元素的变量front以及一个记录队列尾元素位置的变量rear组成;

类比排队,队列元素的添加在尾,元素的删除在头;

队列结构创建:

具体位置表示:

2.顺环队列:

这样的位置排列会出现一个问题:

即无法知道队列是空的还是满的,相应的判断条件都是front=rear

解决办法:

(1)增加标记size,当增加元素时size+1,用来标识元素个数;

(2)仅仅使用n-1个数组空间,即少使用一个数组空间;

我们一般采用方法(2);

相应入队操作:

注意:其中的(ptrq->rear+1) % maxsize代表的是在顺环中,rear元素对应的下一个元素的位置下标;

出队操作:

记住:我们都是在头删除元素,在尾添加元素;

3.队列的链式存储结构:

结构创建:

注意:要额外创建一个结构体,一个存头部指针,一个存尾部指针;

结构图解:

出列操作:

这是一个不带头结点的队列,实际上,front指向的头结点一般为辅助结点(不是空节点),它不存储实际数据,只是为了方便后续插入、删除操作;

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

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

相关文章

2023 年全国职业院校技能大赛(中职组)移动应用与开发赛项 赛题第十套

2023 年全国职业院校技能大赛(中职组)移动应用与开发赛项 赛题第十套) 移动应用与开发赛项竞赛模块 A:移动应用界面设计任务 1 环保中心界面设计(7.5 分)任务 2:首页界面设计(7.5 分…

FPGA为何要尽量减少组合逻辑的使用

在FPGA设计中,组合逻辑的使用确实需要谨慎,尤其是要尽量减少它的复杂性。这并不是因为组合逻辑本身不好,而是因为它在实际应用中容易引发一系列问题,而这些问题往往与FPGA的设计哲学和硬件特性相冲突。让我从几个关键点来和你聊聊…

c语言笔记 字符串函数---strcmp,strncmp,strchr,strrchr

目录 函数strcmp与strncmp 以下是错误的示范:两个指针字符型的指针不能直接进行比较 函数strchr与函数strrchr 函数strchr与函数strrchr与strstr函数三者对比 背景:如果说我们要比较两个字符串是否相等,使用strcmp或者strncmp函数。在c语言中…

合React宝宝体质的自定义节流hook

本文为开发开源项目的真实开发经历,感兴趣的可以来给我的项目点个star,谢谢啦~ 具体博文介绍: 开源|Documind协同文档(接入deepseek-r1、支持实时聊天)Documind 🚀 一个支持实时聊天和接入 - 掘…

【RTSP】客户端(五)H264 265处理逻辑

H264处理逻辑 整体逻辑分析 实现逻辑 解析 RTP 包头:首先检查 RTP 头部的有效负载类型(payloadType)是否匹配处理扩展头:如果 RTP 包包含扩展头,跳过扩展头部分,获取有效负载处理分片数据:H264…

IDEA集成git,项目的克隆,远程仓库中文件的添加删除

目录 一、克隆项目 二、使用IDEA完成文件的上传和删除 1.配置git 2.上传 3.删除(通过git bash) 一、克隆项目 点击克隆,复制url ,如下 打开你想要克隆到哪里,右击,选择 open Git Bash here 这一步之后…

神经网络:定义与核心原理

神经网络(Artificial Neural Network, ANN)是一种受生物神经系统启发的计算模型,旨在通过模拟神经元之间的连接与信息传递机制,实现复杂的数据处理和模式识别功能。其本质是由大量简单处理单元(神经元)构成…

将pdf或者word转换成base64格式

废话不多说直接上代码: function fileToBase64(file) {return new Promise((resolve, reject) > {const reader new FileReader();reader.readAsDataURL(file);reader.onload function (event) {const base64Data event.target.result.split(,)[1];resolve(b…

Spring @Bean注解使用场景二

bean:最近在写一篇让Successfactors顾问都能搞明白的sso的逻辑的文章,所以一致在研究IAS的saml2.0的协议,希望用代码去解释SP、idp的一些概念,让顾问了解SSO与saml的关系,在github找代码的时候发现一些代码的调用关系很难理解&…

ubuntu22.04 关于挂在设备为nfts文件格式无法创建软连接的问题

最近遇到情况,解压工程报错,无法创建软连接 但是盘内还有130G空间,明显不是空间问题,查找之后发现是移动硬盘的文件格式是NTFS,在ubuntu上不好兼容,于是报错。 开贴记录解决方案。 1.确定文件格式 使用命…

docker后台运行,便于后期用命令行进入它的终端

在 docker compose up --build -d 命令中,​**-d​(或 --detach)参数的作用是让容器以后台模式(detached mode)​**运行。以下是详细解释: ​**-d 参数的作用** ​后台运行容器: 默认情况下&a…

网页制作14-Javascipt时间特效の显示动态日期

<!doctype html> <html> <head> <meta charset"utf-8"> <title>动态日期</title> </head><script>var today new Date();//获取时间var ytoday.getFullYear();//截取年var mtoday.getMonth();//截取月份,返回0~11v…

【BP神经网络】实战

1.参考Python实战&#xff1a;BP神经网络_bp神经网络实战python-CSDN博客 2.实践 &#xff08;1&#xff09;运行环境 anocanda Powershell Prompt&#xff08;anocanda3&#xff09; &#xff08;2&#xff09;创建虚拟环境&#xff0c;解决安装包的版本问题 *打开终端&a…

深度学习多模态人脸情绪识别:从理论到实践

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。https://www.captainbed.cn/north 文章目录 1. 引言2. 技术框架与流程图3. 核心算法解析3.1 视觉特征提取&#xff08;CNN&#xff09;3.2…

ssh通过22端口无法连接服务器问题处理

一&#xff0c;安全组开放22端口 root无法连接服务器&#xff0c;22端口也开放了&#xff0c;可能是防火墙开启了拦截。 二&#xff0c;检测防火墙状态 查看防火墙状态 sudo firewall-cmd --state 关闭防火墙 sudo systemctl stop firewalld 开启防火墙 sudo systemctl sta…

element 的tab怎么动态根据参数值添加一个vue页面

在使用 Element UI 的 Tabs 组件时&#xff0c;动态添加 Vue 组件或页面可以通过操作 tabs 数组来实现。假设你要根据参数值来动态添加一个 Vue 页面&#xff08;这里假设是一个 Vue 组件&#xff09;&#xff0c;你可以按照以下步骤操作&#xff1a; 首先&#xff0c;确保你已…

Docker封装镜像、分发、部署实践:nginx

在实际生产工作中&#xff0c;通常是没法直接访问公网的&#xff0c;但是有经常需要使用Docker部署应用&#xff0c;本文将介绍使用Docker从拉取nginx、打包、分发到加载部署nginx的全流程&#xff01; 1 准备工作 1.1 安装docker 请参考&#xff1a;Docker入门指南&#xff…

LuaJIT 学习(5)—— string.buffer 库

文章目录 Using the String Buffer LibraryBuffer ObjectsBuffer Method Overview Buffer Creation and Managementlocal buf buffer.new([size [,options]]) local buf buffer.new([options])buf buf:reset()buf buf:free() Buffer Writersbuf buf:put([str|num|obj] [,……

vue3:request.js中请求方法,api封装请求,方法请求

方法一 request.js // 封装GET请求 export const get (url, params {}) > {return request.get(url, { params }); }; // 封装POST请求 export const post (url, data {}) > {return request.post(url, data); }; api封装 import { post } from /utils/request; …