美文网首页
链栈的操作

链栈的操作

作者: 无聊的CairBin | 来源:发表于2021-10-10 15:17 被阅读0次

链栈的定义

#include <iostream>
using namespace std;

//链栈,理论上只要内存够大不存在上溢,只存在下溢(栈空后继续取出元素)
typedef struct _QNode
{
    int data;
    struct _QNode *next;
}StNode;

链栈的操作

初始化

bool initStack(StNode* &st)
{
    st = new StNode;
    if(!st) return false;
    st->next = NULL;
    return true;
}

判断栈空

bool isEmpty(StNode *st)
{
    if(st->next == NULL)
        return true;
    else
        return false;
}

入栈

bool pushStack(StNode* &st, int e)
{
    
    StNode *node = new StNode;
    if(!node) return false;
    
    
    node->data = e;
    node->next = st->next;
    st->next = node;
    
    return true;
}

出栈

bool popStack(StNode* &st, int &e)
{
    if(!(st->next)) return false;   //栈空
    StNode *p;
    p = st->next;
    
    e = p->data;
    st->next = p->next;
    delete p;
    
    return true; 
}

相关文章

  • 栈和队列

    顺序栈的基本操作: 链栈的基本操作 顺序队的基本操作 链队的基本操作

  • 链栈的操作

    链栈的定义 链栈的操作 初始化 判断栈空 入栈 出栈

  • 堆栈(Stack)---链表实现

    栈的链式存储结构实际上就是一个单链表,叫做链栈。插入和删除操作只能在链栈的栈顶进行。

  • 3. 栈的操作

    1. 栈的操作-c语言实现2. 栈操作的实现-顺序栈和链栈 3. 栈的实现与遍历4. c语言的函数调用栈5. 两个...

  • 数据结构之---栈

    数据结构之---栈 顺序栈 内部采用数组实现 结构图; 定义结构体: 函数声明 进栈以及出栈 图示: 其余操作 链...

  • 【数据结构】【C#】006-栈:💫链栈

    C#数据结构:链栈 1、自定义链栈结构: 链栈节点类 链栈类 链栈测试用例: 输出结果: 注意: 1、链栈即采用链...

  • 栈和队列

    栈和队列 本质上是稍加限制的线性表 栈和队列定义 栈顺序栈定义 链栈结点定义 队列顺序队列 链队列链队类型定义 链...

  • python数据结构实现(栈和链栈)

    栈 链栈

  • 数据结构之栈

    栈:操作受限的线性表,后进先出栈的内部存储既可以用顺序表,也可以用链表,分别称作顺序栈和链栈。 先来实现一个简单的...

  • 栈的两种实现

    实现方式 这里介绍两种实现方式:顺序栈和链栈。 栈的特点 栈作为一种数据结构,是一种只能在一端进行插入和删除操作的...

网友评论

      本文标题:链栈的操作

      本文链接:https://www.haomeiwen.com/subject/qspholtx.html