数据结构之栈和队列

一、栈
栈的逻辑结构,栈:仅限在表尾进行插入和删除操作的线性表。
空栈:不含任何数据元素的栈。允许插入和删除的一端称为栈顶,另一端称为栈底。
栈示意图
栈:操作特性;后进先出,栈只是对表的插入和删除的位置进行了限制,并没有限定插入和删除的进行时间。
栈的顺序存储结构及实现
利用数组实现栈的顺序存储,注意事项:1、确定用数组的哪一端表示栈底。2、附设指针top表示栈顶元素在数组中的位置。3、进出站top加减一,栈空top为-1,栈满为MAX_SIZE-1.
几个重要功能注意事项;入栈先判断栈是否满,出栈先判断栈是否为空,都别忘了操作前对top进行修改。
两栈共享空间:用一个数组来存储两个栈,两个栈从各自的端点向中间延伸。还是注意两个栈各自栈空栈满的条件。

栈的链式存储及实现。
在这里插入图片描述
因为随时可以申请新的内存,所以不用考虑栈满的情况。出栈时只需考虑是否为栈空及top=Null。

顺序栈和链栈的比较:
时间性能相当都是o(1),空间性能,顺序栈有元素个数限制和空间浪费等问题,链栈不用考虑栈满的问题,但是由于要存储指针域,产生了结构性开销。所以当元素个数变化大用链栈,变化小用顺序栈。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值