【软考】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指向的下一个元素所在的指针
相关推荐
@good_good_study4 分钟前
STM32 C语言链表
c语言·stm32·链表
早川9195 分钟前
9种常用排序算法总结
数据结构·算法·排序算法
卷毛迷你猪6 分钟前
小肥柴慢慢手写数据结构(C篇)(2.1.1 动态数组(ArrayList))
c语言·数据结构
Yupureki18 分钟前
《算法竞赛从入门到国奖》算法基础:入门篇-离散化
c语言·数据结构·c++·算法·visual studio
散峰而望20 分钟前
OJ 题目的做题模式和相关报错情况
java·c语言·数据结构·c++·vscode·算法·visual studio code
zc.ovo32 分钟前
线段树优化建图
数据结构·c++·算法·图论
程序员-King.35 分钟前
day140—前后指针—删除排序链表中的重复元素Ⅱ(LeetCode-82)
数据结构·算法·leetcode·链表
Remember_99337 分钟前
【JavaSE】一站式掌握Java面向对象编程:从类与对象到继承、多态、抽象与接口
java·开发语言·数据结构·ide·git·leetcode·eclipse
皮蛋sol周37 分钟前
嵌入式学习数据结构(二)双向链表 内核链表
linux·数据结构·学习·嵌入式·arm·双向链表
WilliamHu.1 小时前
A2A协议
java·数据结构·算法