【软考】9.1 顺序表/链表/栈和队列

《线性结构》

  • 顺序存储和链表存储
  • 每个元素最多只有一个出度和一个入度,表现为一条线状
  • 链表存储结构:每个节点有两个域,即数据,指针域(指向下一个逻辑上相邻的节点)
    在这里插入图片描述
  • 时间复杂度:与其数量级成正比
  • (空间):链表浪费空间
  • (时间):增删改查,链表效率更高
  • (不改变结构操作时,即读取查找):顺序表效率更高
    在这里插入图片描述
  • 栈和队列
  • 栈:先进后出;分队头和队尾
  • 队列:先进先出;只有栈顶能进出
    在这里插入图片描述
  • 循环队列
  • 入队时,修改队尾:
    Q.rear = (Q.rear +1)% MAXSIZE
  • 出队时,修改队头:
    Q.front= (Q.front +1)% MAXSIZE
  • 队列为空时,则:Q.rear == Q.front
  • 队列为满时,则:Q.rear == Q.front
    在这里插入图片描述
  • 区别队列空和队列满的情况:
  • 队列满:队列的尾指针所指位置的下一个位置是队头指针;即
    (Q.rear +1)% MAXSIZE = Q.front
  • 队列空:头、尾指针的值相同;即
    Q.rear = Q.front

    在这里插入图片描述
  • 出栈时没有声明是否有入栈,则输出元素序列不确定
    在这里插入图片描述
  • 全部:所有元素一次性进入队列
  • A中入栈顺序必须是e1,e2,B中必须是e3,e4;由于A和B是相互独立的,则出栈顺序可自由组合
    在这里插入图片描述
  • 队尾的指针:Z所在的指针
  • 队尾元素的指针:Z指向的下一个元素所在的指针
    在这里插入图片描述
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值