用两个栈实现队列(LeetCode)算法题
创始人
2025-05-31 11:57:04
0

直接进入主题

a73849e3266f4b5c8c23e9851d2947dd.png

a831dad00e684d77ac0ebbc4666bb68b.png 

就是这样了,如果没有仔细看题的话,请回去再仔细看一下

下面开讲

先讲思路在来代码

首先我们想一下队列的性质,队列是先进先出,而栈是后进先出,所以如果想要用栈实现队列,那么一个栈肯定是不行的,所以我们定义两个栈,我们来看一下,我们可以定义一个入栈一个出栈

9e15983eee95497080157078c066a3f0.png 

就是这样,我们看一下接下来要怎么做,我们目前有两个栈,根据名字,大家也多少猜出来了,所以我们可以这样,一个栈用来入数据,另一个用来出数据

我们看一下

888b95098ba349118235c8eecfa87669.png 

我们如果要入5个数据1 2 3 4 5

那么我们就直接入到Push栈中

看一下

4a819a8b08594ca382b1751693fbe0e4.png 

就是这样,那么下面如果我们想要出怎么办?而且出去的顺序还是 按照插入顺序出,就是先入先出,所以我们可以把Push栈中的数据给push到Pop栈中

664884f77742499e90228eaf48049869.png 

就是这样所以我们就可以出栈了,那么如果我们还想插入数据怎么做,我们可以继续直接插入到Push栈中

6eb39efedf53413b9f3e071af69972df.png 

所以我们可以直接插入进去,那么如果我们想出呢?

如果我们的Pop栈不为空的话,那我们就是继续直接出,如果Pop栈为空的话就把Push栈中的数据push到Pop栈就可以继续出

Ok这就是思路,所以我们下面看一下代码

13769e4da4e243a596e34dd656ccccb4.png 

首先我们定义一个自己的queue,这个里面有两个栈,一个Push和Pop

下面在看一下

 由于上面的是匿名结构体,所以只能用一次,所以我们需要malloc一个这个类型的结构体

13803de30304419c92e60d2ce077f5c0.png

我们malloc出来以后,我们在调用栈初始化函数,初始化里面的两个栈,最后返回就可以了

f1355292c751424090c3f8ee55a7db01.png 

下面我们看一下如何判断空,如果两个栈都为空,才算是空

下面看一下Push

2b350c01ed5e4af795ed32d234935cf7.png 

这个Push就是直接向Push栈里面插入就可以了

主要是Pop

98d42941970b4d9db521403b63096012.png 

我们看一下Pop,这个Pop的话,就是首先判断是不是为空,如果为空的话,当然是不能Pop的,然后如果我们的Pop栈为空的话,我们就要把Push栈中的数据放到Pop栈中,然后才能Pop,之后就是肯定是有数据的,所以我们记录一下他的Top,然后再Pop掉,就可以了,最后就返回记录的数据

下面看一下Peek,这个就是看队头的数据,这里队头的数据就是Pop栈中的Top数据,所以还是和Pop前面一样,所以我们需要判断Pop栈是否为空,如果为空就是需要转移数据,然后再直接返回Top就可以了

5a467fe4f1ec43279acd59ed6509a1c0.png 

下面在看一下最后的就是释放函数

654fa05958384f40b0705398226c8a36.png 

就是直接释放两个栈里面malloc的空间就可以了

 

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...