栈的实现.

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


引入

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

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

定义

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

过程

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

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

        构建栈

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

        向栈顶插入(写入)数据

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

        从栈顶弹出数据

        直接tt--,使栈减少一层。

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

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

        取栈顶值

        输出stk[tt]的值即可。

        判断栈是否为空

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

性质

        时间复杂度

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

代码

        下面给出栈的实现代码:

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++算法基础专栏文章    下一篇-表达式求值问题的实现


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

点个赞,关注一下呗~

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值