数据结构-栈的详细整理

本文详细介绍了如何使用C++实现一个栈,并提供了栈的基本操作,如push元素到栈顶、pop弹出栈顶元素、empty判断栈是否为空以及query查询栈顶元素。同时,文中还提到了STL中的相关stack函数及其时间复杂度分析。
摘要由CSDN通过智能技术生成

// TOP表示栈顶

int stk[N], TOP = 0;

// 向栈顶插入一个数

stk[ ++ TOP] = x;

// 从栈顶弹出一个数

TOP – ;

// 栈顶的值

stk[TOP];

// 判断栈是否为空

if (TOP > 0)

{

}

题目练习

实现一个栈,栈初始为空,支持四种操作:

(1) “push x” – 向栈顶插入一个数x;

(2) “pop” – 从栈顶弹出一个数;

(3) “empty” – 判断栈是否为空;

(4) “query” – 查询栈顶元素。

现在要对栈进行M个操作,其中的每个操作3和操作4都要输出相应的结果。

输入格式

第一行包含整数M,表示操作次数。

接下来M行,每行包含一个操作命令,操作命令为”push x”,”pop”,”empty”,”query”中的一种。

输出格式

对于每个”empty”和”query”操作都要输出一个查询结果,每个结果占一行。

其中,”empty”操作的查询结果为“YES”或“NO”,”query”操作的查询结果为一个整数,表示栈顶元素的值。

数据范围

1≤M≤100000,

1≤x≤109

所有操作保证合法。

输入样例:

10

push 5

query

push 6

pop

query

pop

empty

push 4

query

empty

输出样例:

5

5

YES

4

NO

代码

#include

#include

#include

#include

using namespace std;

const int maxn = 1e5 + 10;

int st[maxn];

int main()

{

int M,TOP=0;

cin >> M;

while (M–)

{

string str;

int x;

cin >> str;

if (str == “push”)

{

cin >> x;

st[++TOP] = x;

}

else if(str == “query”)

{

cout << st[TOP] << endl;

}

else if (str == “pop”)

{

TOP–;

}

else if (str == “empty”)

{

if (TOP > 0)

{

cout << “NO” << endl;

}

else

{

cout << “YES” << endl;

}

}

}

return 0;

}

STL中stack常用函数解析

(1) push()

push(x)将x入栈,时间复杂度为O(1).

(2) top()

top()获得栈顶元素,时间复杂度为O(1).

(3) pop()

pop()用以弹出栈顶元素,时间复杂度为O(1).

示例如下

#include

#include

using namespace std;

int main()

{

stackst;

for (int i = 1; i <= 5; i++)

{

st.push(i); //将 1 2 3 4 5 一次入栈

}

for (int i = 1; i <= 3; i++)

{

st.pop(); //连续三次将栈顶元素出栈,即将5 4 3 依次出栈

}

cout << st.top() << endl; //输出2

return 0;

}

(4) empty()

empty()可以检测stack内是否为空,为空返回true,否则返回false,时间复杂度为O(1)。

(5) size()

size()返回stack内元素的个数,时间复杂度为O(1)。

示例如下

#include

#include

using namespace std;

int main()

{

stackst;

if (st.empty() == 1)

{

cout << “YES” << endl;//刚开始栈内没有元素,因此为空。

}

for (int i = 1; i <= 5; i++)

{

st.push(i);

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

我的面试宝典:一线互联网大厂Java核心面试题库

以下是我个人的一些做法,希望可以给各位提供一些帮助:

整理了很长一段时间,拿来复习面试刷题非常合适,其中包括了Java基础、异常、集合、并发编程、JVM、Spring全家桶、MyBatis、Redis、数据库、中间件MQ、Dubbo、Linux、Tomcat、ZooKeeper、Netty等等,且还会持续的更新…可star一下!

image

283页的Java进阶核心pdf文档

Java部分:Java基础,集合,并发,多线程,JVM,设计模式

数据结构算法:Java算法,数据结构

开源框架部分:Spring,MyBatis,MVC,netty,tomcat

分布式部分:架构设计,Redis缓存,Zookeeper,kafka,RabbitMQ,负载均衡等

微服务部分:SpringBoot,SpringCloud,Dubbo,Docker

image

还有源码相关的阅读学习

image

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
部分:Spring,MyBatis,MVC,netty,tomcat

分布式部分:架构设计,Redis缓存,Zookeeper,kafka,RabbitMQ,负载均衡等

微服务部分:SpringBoot,SpringCloud,Dubbo,Docker

[外链图片转存中…(img-fU09rD2x-1713712622144)]

还有源码相关的阅读学习

[外链图片转存中…(img-iMsh0FFs-1713712622144)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值