第三章:栈和队列

栈和队列是两种常用的数据结构,同时又是操作受限的线性表,也是两种重要的抽象数据类型。

11栈是限定仅在表尾进行插入和删除操作的线性表。  栈中元素具有线性关系和后进先出的特性。

2虽然对插入和删除操作的位置限制减少了栈的灵活性,但同时也使得栈的操作更有效更容易实现。

3栈的存储结构分两种,一种是顺序存储结构,一种是链接存储结构。第一种称为顺序栈,由于栈元素的数据类型不确定,所以采用C++模板机制实现。第二种是链栈,链栈的结点结构可以复用单链表的结点结构,将栈的抽象数据类型定义在链栈存储结构下用C++中的类实现。

4当链栈跟顺序栈做比较时,若使用过程中元素个数变化较大时,用链栈最适宜,因为链栈没有栈满问题,只有当内存没有可用空间时才会出现栈满,但是每个元素都需要一个指针域,从而产生了结构性开销;反之,采用顺序栈,初始时顺序栈必须确定一个固定长度,所以又存储元素个数的限制和空间浪费问题。

21队列是只允许在一端进行插入操作,在另一端进行删除操作的线性表。队列中元素具有线性关系和先进先出的特性。

2队列的存储结构也分两种,一种是循环队列,另一种是链队列。队列元素数据类型不确定,所以采用C++模板机制实现。

3循环队列和链队列比较时,循环队列不能像顺序栈那样共享空间,通常不能在一个数组中存储两个循环队列,所以两者的比较与链栈和顺序栈的比较相类似。

4循环队列的实现包括五个步骤:构造函数、入队操作、出队操作、读取队头元素、判空操作;然而链队列的实现则有六个步骤:构造函数、入队操作、出队操作、读取队头元素、判空操作、析构函数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值