leetcode 255.用队列实现栈

255.用队列实现栈

不出意外大概率这几天都会更新 leetcode,如果没有做新的题,大概就会把 leetcode 之前写过的题整理(单链表的题目居多一点)出来写成博客

今天讲的题蛮容易出错的(注意传参啊,最好把队列的实现写过一遍,写起来就容易一点)


题目

请你仅使用两个队列实现一个后入先出(LIFO)的栈,并支持普通栈的全部四种操作(push、top、pop 和 empty)。

实现 MyStack 类:

  • void push(int x) 将元素 x 压入栈顶。
  • int pop() 移除并返回栈顶元素。
  • int top() 返回栈顶元素。
  • boolean empty() 如果栈是空的,返回 true ;否则,返回 false 。

题目链接

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

文字 和 画图 分析

  1. 首先思考一下 栈 和 队列 两者之间 的区别:

栈:先进后出(用数组实现) 队列:先进先出(用链表实现)

栈:

队列:

      2. 最大的问题就是 出元素

   

明显一个队列我们不好模拟出栈,这里我们就要借助 两个队列去实现

栈是出 存进去的最后一个元素,而队列是出 存进去的第 一 个元素,要想两者对等,即第一个元素也就是最后 一个元素

我们把存放所有元素的那一个队列,除了最后一个元素, 其它的元素都移到没有存放元素的那一个队列,这样就做 到第一个元素也就是最后一个元素

      3. 存入元素

这里我们需要确保其中一个队列始终为空(有利于后面的 出元素),另一个队列专门存入元素,由于后续的出元素 导致我们无法确保哪一个队列存元素,哪一个队列为空 (如果 q1存元素,进行一次出元素之后,它就为空了 ),

这里我们用了一个方法:再定义两个指针 nonEmpty 和 Empty,用来存放 两个队列 的地址,开始nonEmpty存放 q1的地址,Empty存放q2的地址,判断 q1是否为空,如 果为空,nonEmpty存放q2的地址,Empty存放q1的地址

(也可以之间用 if ,else语句直接判断)


代码

typedef int QLType;
typedef struct QueueNode
{QLType val;struct QueueNode* next;
}QN;//创建节点
typedef struct QueueList
{QN* head;QN* tail;int size;
}QL;//创建队列
void QNInit(QL* pphead)
{pphead->head = pphead->tail = NULL;pphead->size = 0;
}//队列初始化
QLType QLTop(QL* pphead)
{return pphead->head->val;
}//返回列队的头节点元素
QLType QLtail(QL* pphead)
{return pphead->tail->val;
}//返回列队的尾节点元素
int  QLSize(QL* pphead)
{return pphead->size;
}//返回队列里面有效元素个数
bool QLEmpty(QL* pphead)
{return pphead->head == NULL;
}//判断队列是否为空
void QNPop(QL* pphead)
{QN* cur = pphead->head;pphead->head = pphead->head->next;free(cur);pphead->size--;
}//出队列存储的第一个元素
void QNPush(QL* pphead, QLType x)
{QN* newnode = (QN*)malloc(sizeof(QN));newnode->next = NULL;newnode->val = x;if (newnode == NULL){perror("malloc");return;}if (QLEmpty(pphead)){pphead->head = pphead->tail = newnode;}else{pphead->tail->next = newnode;pphead->tail = newnode;}pphead->size++;
}//存入队列元素//以上都是服务队列的创建typedef struct 
{QL q1;QL q2;
}MyStack//存放两个队列MyStack* myStackCreate() 
{MyStack* obj = (MyStack*)malloc(sizeof(MyStack));QNInit(&obj->q1);QNInit(&obj->q2);return obj;
} //两个队列的初始化void myStackPush(MyStack* obj, int x) 
{if(!QLEmpty(&obj->q1)){QNPush(&obj->q1,  x);}else{QNPush(&obj->q2,  x);}
}//存放元素int myStackPop(MyStack* obj)
{QL *nonEmpty = &obj->q1;QL *Empty = &obj->q2;if(QLEmpty(&obj->q1)){nonEmpty = &obj->q2;Empty = &obj->q1;}while(QLSize(nonEmpty) > 1){QNPush(Empty, QLTop(nonEmpty));QNPop(nonEmpty);}int top = QLTop(nonEmpty);QNPop(nonEmpty);return top;
}//出元素int myStackTop(MyStack* obj) 
{if(!QLEmpty(&obj->q1)){return QLtail(&obj->q1);}else{return QLtail(&obj->q2);}
}//返回栈顶元素bool myStackEmpty(MyStack* obj) 
{return  QLEmpty(&obj->q1) && QLEmpty(&obj->q2);
}//判断两个栈是否都为空void myStackFree(MyStack* obj) 
{free(obj);
}//销毁空间

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

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

相关文章

渗透测试——五、网站漏洞——SQL注入

一、走进DVWA测试网站 1、网站渗透测试步骤 (1)收集信息 1、获取域名的 Whois 信息,获取注册者邮箱、姓名、电话等。2、查询服务器旁站及子域名站点,因为主站一般比较难,所以先看看旁站有没有通用性的CMS或者其他漏洞。3、查看服务器操作系…

解决 nginx 504 Gateway Time-out报错问题

国内GPT4站点:海鲸AI 要延长 Nginx 服务器在返回 504 Gateway Time-out 错误之前等待上游服务器响应的时间,你需要修改 Nginx 配置文件中的超时设置。以下是一些可能需要调整的指令: proxy_connect_timeout:代理服务器与上游服务…

ROS话题通信基本操作(C++)

目录 一、发布 1、实现步骤 2、代码实例 二、接收 1、实现步骤 2、代码实例 三、配置运行 1、修改CMakeLists.txt 2、运行结果 一、发布 1、实现步骤 1.包含头文件 2.初始化 ROS 节点:命名(唯一) 3.实例化 ROS 句柄 4.实例化 发布者 对象 5.组织被发布的数据&#…

Pytest做性能测试?

Pytest其实也是可以做性能测试或者基准测试的。是非常方便的。 可以考虑使用Pytest-benchmark类库进行。 安装pytest-benchmark 首先,确保已经安装了pytest和pytest-benchmark插件。可以使用以下命令安装插件: pip install pytest pytest-benchmark …

JSP控制项目启动后默认去访问指定的WebServlet 而不是index.jsp

我的 index.jsp 代码是这样 现在每次启动 访问的都是index.jsp 这也是它的默认配置 我这里写了一个 WebServlet 代码是这样 简单可以理解为 我们定义了WebServlet 访问路径为1cginServlet 其中在request作用域中 定义了一个userName值为 欢迎来到jsp世界 然后 跳转向 page.j…

十年婚姻·总结三

十年婚姻总结三 婚姻这个制度,就不是为了保护爱情和情感的,是为了保护财产和育儿 婚姻这个制度,就不是为了保护爱情和情感的,是为了保护财产和育儿 问题:为什么男人喜欢外面的女人,也不离婚? …

Rust编程语言入门教程(三)-trait

文章目录 Rust编程语言入门教程(三)-trait什么是 trait?trait使用举例 Rust编程语言入门教程(三)-trait 什么是 trait? trait 是 Rust 中的接口,它定义了类型使用这个接口的行为。你可以类比到…

Android : AndroidStudio开发工具优化

1.开启 gradle 单独的守护进程 Windows: 进入目录 C:\Users\Administrator\.gradle 创建文件: gradle.properties # Project-wide Gradle settings. # IDE (e.g. Android Studio) users: # Settings specified in this file will override any Gradle s…

前端时间的失败总结复盘

分享失败经验,前段时间的总结复盘: 与伙伴合作面对异常决策要及时提出质疑,怼,别太客气,客气起来,小心翼翼在意他人情绪那么这个项目就会让人难受,不要因为因为伙伴身上有标签/光环/权威就觉得…

怎么把视频转换为gif?

怎么把视频转换为gif?视频和 GIF 动图在许多方面都有所不同,主要的区别包括它们的数据格式、播放方式以及用途。视频:通常以常见的视频格式如MP4、AVI、MOV等存储,它们包含了连续的图像帧以及音频轨道(如果有的话&…

ISP算法简述-BLC

Black Level Calibration, 黑电平矫正 现象 1)在纯黑条件下拍张图,你会发现像素值不为0 2)或者你发现图像整体偏色 这些问题可能是黑电平导致的。 原因 存在黑电平的原因有2个: 1)sensor的电路本身存在暗电流。暗电流主要产生在光电信号转换过程中&#…

国内某求职app遭“撞库”攻击,百万条用户数据泄露

什么是撞库? 简单来说:一些用户为了方便记忆,会采用相同的账户密码登录多个网站或app,甚至是存储关键信息的系统平台。如果其中一个平台有漏洞被黑客利用窃取了账户名和密码,黑客便用这套凭证登录大量测试所有平台&am…

葡萄酒的储存条件会影响葡萄酒的陈酿吗?

自20世纪末以来,葡萄酒储存有关的行业一直在增长,一些葡萄酒鉴赏家可能会选择将葡萄酒存放在家里的专用房间或壁橱里。 自云仓酒庄品牌雷盛红酒分享总所周知,瓶装葡萄酒的储存条件是会影响葡萄酒的陈酿,振动和热波动会加速葡萄酒的…

COCO格式标签(json)内容可视化(python)

主要是查到的可用代码,便于自己使用查询,和有相关需求的提供参考。 代码是MMYOLO下的可视化代码browse_coco_json.py,有json文件和图像文件,可以直接输入执行,输出会把bbox、mask等类型标注展示。 下面直接上代码&am…

【深度学习笔记】09 权重衰减

09 权重衰减 范数和权重衰减利用高维线性回归实现权重衰减初始化模型参数定义 L 2 L_2 L2​范数惩罚定义训练代码实现忽略正则化直接训练使用权重衰减 权重衰减的简洁实现 范数和权重衰减 在训练参数化机器学习模型时,权重衰减(decay weight&#xff09…

python中获取函数签名(参数)

说明 有些时候我们不清楚python的函数的具体签名的时候,调用可能会报错,这里就是介绍一种简单的方法来获取函数的签名参数。 语法 获取函数的参数签名可以使用 组件.函数.__signature__示例: 我想要获取streamlit.text_input函数的参数签…

golang开发之个微机器人开发

请求URL: http://域名地址/sendFile 请求方式: POST 请求头Headers: Content-Type:application/jsonAuthorization:login接口返回 参数: 参数名必选类型说明wId是string登录实例标识wcId是string接收…

使用Redis实现购物车后端处理

本文中心思想:实现购物车的后端处理逻辑。 本文将教会你掌握:1.存储商品信息,2.存储购物车信息,3.获取购物车信息。 存储商品信息 商品包含多个属性,例如:名字&#x…

it资产管理系统

it资产管理系统这个词组初听有些陌生,再听却别有一种科技感。 先来看下it资产管理系统的定义: 它是一种针对企业IT资产进行全面管理和监控的工具,它可以帮助企业实现对IT资源的有效利用和合理配置,提高企业的运营效率和市场竞争力…

查看php进程占用内存

要查看每个PHP中Swoole进程占用的内存,您可以使用Linux的一些工具和命令来实现。 使用ps命令列出正在运行的进程,可以通过进程名或进程ID(PID)过滤结果: ps aux | grep php这将显示与PHP相关的进程列表。 通过top命令…