stack容器

13 篇文章 0 订阅
11 篇文章 0 订阅

一个人,要犯下多少恶行 才能在地狱的尽头,将她带回黎明 一个人,要走多远的距离 才能在时光的尽头,追回最初的自己

 用自己的一切换一个只有过去的自己可以触摸到的未来值得么

stack容器

栈的定义:

  • 线性结构的两种常见应用之一栈 定义:

    • 一种可以实现”先进后出”的存储结构,

    • 栈类似于箱子 分类:静态栈、动态栈

    • 算法:出栈、压栈

  • 栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

栈的逻辑定义、特点及运算:

  • 栈是限定在表的一端进行插入和删除的运算的线性表,通常将插入、删除的一端称为栈顶,另一端称为栈底。不含元素的空表称为空栈。栈的操作具有先进后出或后进先出的特点。栈的运算主要有置空栈、判栈空、判栈满、进栈、退栈、和取栈顶元素6种。

基本概念

  • 要搞清楚这个概念,首先要明白”栈“原来的意思,如此才能把握本质。"栈“者,存储货物或供旅客住宿的地方,可引申为仓库、中转站,所以引入到计算机领域里,就是指数据暂时存储的地方,所以才有进栈、出栈的说法。

  • 首先系统或者数据结构栈中数据内容的读取与插入(压入push和 弹出pop)是两回事!压入是增加数据,弹出是删除数据 ,这些操作只能从栈顶即最低地址作为约束的接口界面入手操作 ,但读取栈中的数据是随便的没有接口约束之说。很多人都误解这个理念从而对栈产生困惑。而系统栈在计算机体系结构中又起到一个跨部件交互的媒介区域的作用 即 cpu 与内存的交流通道 ,cpu只从系统给我们自己编写的应用程序所规定的栈入口线性地读取执行指令, 用一个形象的词来形容它就是pipeline(管道线、流水线)。cpu内部交互具体参见 EU与BIU的概念介绍。

  • 栈作为一种数据结构,是一种只能在一端进行插入和删除操作的特殊线性表。它按照先进后出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来)。栈具有记忆作用,对栈的插入与删除操作中,不需要改变栈底指针。

  • 栈是允许在同一端进行插入和删除操作的特殊线性表。允许进行插入和删除操作的一端称为栈顶(top),另一端为栈底(bottom);栈底固定,而栈顶浮动;栈中元素个数为零时称为空栈。插入一般称为进栈(PUSH),删除则称为退栈(POP)。栈也称为先进后出表。

  • 栈可以用来在函数调用的时候存储断点,做递归时要用到栈!

  • 以上定义是在经典计算机科学中的解释。

    • 在计算机系统中,栈则是一个具有以上属性的动态内存区域。程序可以将数据压入栈中,也可以将数据从栈顶弹出。在i386机器中,栈顶由称为esp的寄存器进行定位。压栈的操作使得栈顶的地址减小,弹出的操作使得栈顶的地址增大。

    • 栈在程序的运行中有着举足轻重的作用。最重要的是栈保存了一个函数调用时所需要的维护信息,这常常称之为堆栈帧或者活动记录。堆栈帧一般包含如下几方面的信息:

    • 1.函数的返回地址和参数

    • 2. 临时变量:包括函数的非静态局部变量以及编译器自动生成的其他临时变量。

基本算法

  • 1.进栈(PUSH)算法

①若TOP≥n时,则给出溢出信息,作出错处理(进栈前首先检查栈是否已满,满则溢出;不满则作②);

②置TOP=TOP+1(栈指针加1,指向进栈地址);

③S(TOP)=X,结束(X为新进栈的元素);

  • 2.退栈(POP)算法

①若TOP≤0,则给出下溢信息,作出错处理(退栈前先检查是否已为空栈, 空则下溢;不空则作②);

②X=S(TOP),(退栈后的元素赋给X):

③TOP=TOP-1,结束(栈指针减1,指向栈顶)。

栈分顺序栈和链式栈,下面程序介绍了顺序栈的实现。

pascal 1.数组型

Const

m=栈表目数的上限;

Type

stack=array[1..m] of stype; {栈类型}

Var

s:stack;{栈}

top:integer;

2.记录型

const

m=栈表目数的上限;

type

stack=record

elem: array[1..m] of elemtp;

top:0..m; {栈顶指针}

end;

Var

s:stack;{栈}

stack容器基本概念

概念:stack是一种先进后出(first in last out , filo )的数据结构,它只有一个出口

 

栈中只有顶端的元素才可以被外界使用,因此栈不允许有遍历行为

stack容器的操作

函数意义使用
empty判断栈是否为空if(a.empty()) { cout << "栈为空栈" << endl; } else { cout << "栈不为空栈" << endl; cout << "栈中有" << a.size() << "个元素" << endl;; }
size()返回栈的大小(入栈时记录)cout << "栈中有" << a.size() << "个元素" << endl;
push(elem)入栈(栈中进入数据),向栈顶添加元素int b; cout << "输入要入栈的元素数量" << endl; cin >> b; for (int i = 0; i < b; i++) { int d; cout << "输入要存入栈的元素" << endl; cin >> d; a.push(d); }
pop()出栈(栈中弹出数据),从栈顶移除第一个元素int y; cout << "输入要取出栈的元素的数量" << endl; cin >> y; for (int i = 0; i < y; i++) { a.pop(); }
top()返回栈顶元素int b=a.size(); cout << "栈中元素为" << endl; for (int i = 0; i < b; i++) { cout << a.top()<<" "; a.pop(); }

stack常用接口

功能描述:栈容器常用的对外接口

stack构造函数

 

赋值操作

 数据存取

 

大小操作

 

#include<iostream>
#include<stack>
using namespace std;
​
void push(stack<int>&a) 
{
    int b;
    cout << "输入要入栈的元素数量" << endl;
    cin >> b;
    for (int i = 0; i < b; i++) 
    {
        int d;
        cout << "输入要存入栈的元素" << endl;
        cin >> d;
        a.push(d);
    }
}
​
void pop(stack<int>& a) 
{
    int y;
    cout << "输入要取出栈的元素的数量" << endl;
    cin >> y;
    for (int i = 0; i < y; i++)
    {
        a.pop();
    }
}
​
void empty(stack<int>a)   
{
    if(a.empty())
    {
        cout << "栈为空栈" << endl;
    }
    else
    {
        cout << "栈不为空栈" << endl;
        cout << "栈中有" << a.size() << "个元素" << endl;;
    }
}
​
void printstack(stack<int>a) //利用copy让其不删
{
    int b=a.size();
    cout << "栈中元素为" << endl;
    for (int i = 0; i < b; i++) 
    {
        cout << a.top()<<"  ";
        a.pop();
    }
}
int main()
{
    stack<int>a;
    push(a);
    printstack(a);
    cout << endl;
    cout << endl;
    pop(a);
    printstack(a);
    cout << endl;
    cout << endl;
    empty(a);
    system("pause");
    return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只符华单推人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值