栈的基本算法

Posted xyq-208910

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了栈的基本算法相关的知识,希望对你有一定的参考价值。

一、简单介绍
栈是限定进在表尾插入或删除操作的线性表。因此,对栈来说,表尾端有其特殊的含义,成为栈顶(top),相应地,表头端称为栈底(bottom)。

不含元素的空表称为空栈。栈的修改是按照后进先出的原则进行的,因此,栈又称为后进先出的线性表。

 

二、栈示意图

技术图片

 

三、基本操作

1、栈的初始化: InitStack(&S)
2、栈顶元素插入: Push(&S, &e)
3、栈顶元素获取: GetTop(&S, &e)
4、栈顶元素删除: Pop(&S, &e)
5、栈的长度: StackLength(S)
6、栈的判空: StackEmpty(S)
7、栈元素的访问: StackTraverse(S, visit())
8、栈的清空: ClearStack(&S)
9、栈的销毁: DestroyStack(&S)

 

四、栈顺序存储的实现

//---------- 栈的顺序存储表示 ---------
#define STACK_INIT_SIZE 100; //存储空间初始分配量
#define STACKINCREMENT  10;  //存储空间分配增量
typedef struct 
    SElemType *base; //在栈构造之前和销毁之后,base的值为NULL
    SElemType *top;  //栈顶指针
    int stacksize;   //当前已分配的存储空间,以元素为单位 
SqStack;
//---------- 基本操作的函数原型声明 --------
Status InitStack(SqStack &S);    //构造一个空栈S
Status DestroyStack(SqStack &S); //销毁栈S,S不再存在
Status ClearStack(SqStack &S);   //把S置为空栈
Status StackEmpty(SqStack &S);   //若栈S为空栈,则返回TRUE,否则返回FALSE
int StackLength(SqStack &S);     //返回S的元素个数,即栈的长度
Status GetTop(SqStack &S, SElemType &e); //若栈S不空,则用e返回S的栈顶元素,并返回OK,否则返回ERROR
Status Push(SqStack &S, SElemType &e);   //插入元素e为新的栈顶元素
Status Pop(SqStack &S, SElemType &e);    //若栈S不空,则删除S的栈顶元素e,用e返回其值,返回OK,否则返回ERROR
Status StackTraverse(S, visit(SElemType e));        //从栈顶到栈顶依次对每一个元素调用函数visit()。一旦visit()失败,则操作失败
//---------- 基本操作的算法描述 --------
Status InitStack(SqStack &S)
    S.base = (SElemType *)malloc(STACK_INIT_SIZE * sizeof(SElemType))
    if(!S.base) exit(OVERFLOW); //存储分配失败
    S.top = S.base;
    S.stacksize = STACK_INIT_SIZE;
    return OK;


Status DestroyStack(SqStack &S)
    free(S.base);
    S.base = NULL;
    S.top = NULL;
    S.stacksize = 0;
    return OK;


Status ClearStack(SqStack &S)
    S.top = S.base;
    return OK;


Status StackEmpty(SqStack &S)
    if(S.top = S.base) return TRUE;
    return FALSE;


int StackLength(SqStack &S)
    return S.top - S.base;


Status GetTop(SqStack &S, SElemType &e)
    if(S.top = S.base) return ERROR;
    e = *(S.top - 1);
    return OK;


Status Push(SqStack &S, SElemType &e)
    if(S.top - S.base >= S.stacksize)  //栈满,追加存储空间
        S.base = (SElemType *)realloc(S.base, (S.stacksize + STACKINCREMENT) * sizeof(SElemType));
        if(!S.base) exit(OVERFLOW); //存储分配失败
        S.top = S.base + S.stacksize;
        S.stacksize += STACKINCREMENT;
    
    * S.top++ = e;
    return OK;


Status Pop(SqStack &S, SElemType &e)
    if(S.top = S.base) return ERROR;
    e = * --S.top;
    return OK;


Status StackTraverse(S, visit())
    while(S.top > S.base)
        visit(*S.base++);
    return OK;

Status visit(SElemType e)

    printf("%d ", e);
    return OK;

 

以上是关于栈的基本算法的主要内容,如果未能解决你的问题,请参考以下文章

算法7---栈及其基本操作实现

栈的应用(括号匹配算法实战)

[算法] leetcode_括号匹配问题

对栈的操作和算法实现

C语言 任意表达式求值。(栈的应用

数据结构与算法目录