数据结构遍历顺序栈_数据结构与算法(五)--- 栈

本文介绍了栈这种数据结构,包括它的先进后出原则和两种存储方式:顺序存储和链式存储。顺序存储通过数组实现,链式存储通过链表实现,两者都有各自的初始化、入栈、出栈、遍历等操作。此外,还提到了递归的概念以及汉诺塔问题的递归解决方案。
摘要由CSDN通过智能技术生成

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

遵循先进后出原则

125b0f617406

栈.png

顺序存储栈

物理结构是顺序存储,先开辟一块内存空间,每push一个新元素,栈顶标记top+1,直到开辟的空间被存满。每Pop一个栈顶元素,top-1,下一个元素变成栈顶元素。

1. 结构定义

#define ERROR 0

#define TRUE 1

#define FALSE 0

#define OK 1

#define MAXSIZE 20 /* 存储空间初始分配量 */

typedef int Status;/* Status是函数的类型,其值是函数结果状态代码,如OK等 */

typedef int ElemType;/* ElemType类型根据实际情况而定,这里假设为int */

/* 顺序栈结构 */

typedef struct

{

ElemType data[MAXSIZE];

int top; /* 用于栈顶指针 */

}Stack;

2. 代码实现

初始化一个空栈

Status InitStack(Stack *S)

{

S->top = -1;

return OK;

}

清空栈(置空)

Status ClearStack(Stack *S)

{

S->top = -1;

return OK;

}

判断栈是否为空

Status StackIsEmpty(Stack S) {

if (S.top == -1) return TRUE;

else return FALSE;

}

栈的长度

int StackLength(Stack S) {

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值