顺序栈的操作

栈的定义

#include <iostream>
#define MAXSIZE 1000

using namespace std;

//顺序栈
typedef struct
{
    int data[MAXSIZE];  //存放栈顶元素
    int top;            //栈顶指针
}SqStack;

栈的操作

初始化

//初始化顺序栈
bool initStack(SqStack &st)
{
    st.top = -1;
    return true;
}

判断为空

//判断栈是否为空
bool isEmpty(SqStack st)
{
    if(st.top == -1)
        return true;
    else
        return false;
}

入栈

bool pushStack(SqStack &st, int e)
{
    if(st.top == MAXSIZE - 1)
        return false;   //栈已满,再入栈会上溢
    //对于入栈,一定要先改指针再入
    st.top++;
    st.data[st.top] = e;
    return true;
}

出栈

bool popStack(SqStack &st, int &e)
{
    if(st.top == -1)
        return false;   //栈空不能继续出栈,否则下溢
    
    //对于出栈,先出元素再取指针
    e = st.data[st.top];
    st.top--;
    
    return true;
}

获取栈顶元素

//获取栈顶元素
bool getStackTopElem(SqStack st, int &e)
{
    if(st.top == -1)
        return false;   //栈空,无元素返回
    e = st.data[st.top];
    return true;
}
posted @   CairBin  阅读(69)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示