栈的实现.

这是C++算法基础-数据结构专栏的第二十一篇文章,专栏详情请见此处


引入

栈是一种常用的一种线性数据结构。它的使用非常广泛,例如在函数调用中用于保存局部变量、在表达式求值中用于保存操作数等。

下面我们就来讲栈的实现。

定义

栈(stack)的修改与访问是按照后进先出的原则进行的,因此栈通常被称为是后进先出(last in first out)表,简称 LIFO 表。

过程

栈就像一个桶,只有一个开口,你往里放东西,等到你要拿东西的时候,第一个拿出来的一定是最后一个放进去的,这就叫先进后出。

我们接下来要学习五种栈的最主要操作:构建,插入(写入)数据、删除数据、取栈顶值、判断栈是否为空

构建栈

我们先定义一个数组,用来表示 ,接着还需要一个变量,用来表示栈顶

向栈顶插入(写入)数据

先在栈顶进行数据赋值 ,然后将

从栈顶弹出数据

直接,使栈减少一层。

Q:将栈减少一层,栈中还有刚刚的数据,直接做会不会有问题呢?

A:没有关系,将栈顶减少一层,就无法访问刚才的数据了,若后来插入数据,数据会被覆盖掉。所以,直接操作栈顶就可以实现了。

取栈顶值

输出的值即可。

判断栈是否为空

判断栈顶的位置 ,若,说明栈为空,反之也成立。

性质

时间复杂度

上述关于栈的操作,时间复杂度都是的。

代码

下面给出栈的实现代码:

复制代码
int stk[N],tt=0;

void push(int x){
    stk[++tt]=x;
}

void pop(){
    tt--;
}

int top(){
    return stk[tt];
}

bool empty(){
    if(tt==0) 
        return 1;
    else
        return 0;
}
代码解释

第一行的各种变量和数组已经在前面讲解了,这里不再详细讲解;push()函数的作用是向栈顶插入(写入)数据;pop()函数的作用是从栈顶弹出数据;top()函数的作用是取栈顶值;empty()函数的作用是判断栈是否为空。


上一篇-双链表的实现 C++算法基础专栏文章 下一篇-表达式求值问题的实现


每周六更新一篇文章,内容一般是自己总结的经验或是在其他网站上整理的优质内容

点个赞,关注一下呗~

相关推荐
Larry_Yanan1 小时前
Qt多进程(一)进程间通信概括
开发语言·c++·qt·学习
J ..2 小时前
C++ 多线程编程基础与 std::thread 使用
c++
你的冰西瓜2 小时前
C++标准模板库(STL)全面解析
开发语言·c++·stl
闻缺陷则喜何志丹2 小时前
【计算几何】仿射变换与齐次矩阵
c++·数学·算法·矩阵·计算几何
chen_ever2 小时前
Protobuf详解(从安装到实战)
c++·rpc·信息与通信
hmbbcsm3 小时前
python做题小记(八)
开发语言·c++·算法
再睡一夏就好3 小时前
深入Linux线程:从轻量级进程到双TCB架构
linux·运维·服务器·c++·学习·架构·线程
特立独行的猫a4 小时前
C++开发中的Pimpl机制与类声明机制深度解析:现代C++的编译解耦艺术
开发语言·c++·pimpl
GoWjw4 小时前
在C&C++指针的惯用方法
c语言·开发语言·c++
君义_noip4 小时前
信息学奥赛一本通 1453:移动玩具 | 洛谷 P4289 [HAOI2008] 移动玩具
c++·算法·信息学奥赛·csp-s