数据结构各结构特点(数组、链表、栈、队列、树)(上)

简介: 数据结构各结构特点(数组、链表、栈、队列、树)

一、数组

简介:

数组是一种线性表结构,元素序列有序,在内存中开辟一段连续的内存空间。数组具有随机访问的优势,可以通过下标访问元素,时间复杂度为 O (1),但插入删除操作比较复杂,需要移动其他元素,所以时间复杂度为 O (n)。

特点:

1. 数组在逻辑上、内存中都是连续的,数组需要开辟一段连续的内存空间

2. 查找元素快:通过索引,可以快速访问指定位置的元素

3. 增删元素慢:因为数组长度是固定的,如果插入删除元素的话,就要涉及到元素的移动。

缺点:

1. 插入删除操作所需要移动的元素很多,效率低下。

2. 数组在内存中是一段连续的内存空间,所以必须为数组开辟足够的空间,否则有溢出的风险。

二、链表

简介:

链表也是一种线性表结构,但它在内存中不一定是连续的。即逻辑上连续,物理存储结构上不连续,大小不固定。

链表基于指针实现,它的存储单元以结点为单位,每一个结点由数据域和指针域组成。

数据域:存储数据元素信息的域

指针域:存储直接后继位置的域。

遍历链表需要从头结点开始依次往后遍历,每个节点只有一个前驱结点,每个节点只有一个后继结点,首结点没有前驱结点,尾结点没有后续结点。

特点:

1. 通过指针的形式将一组存储单元联系在一起的数据结构

2. 逻辑上连续,物理存储结构上不连续,大小不固定

3. 单链表维护一个单向的指针,通过指针寻找下一存储单元;双链表维护一个双向的指针,通过指针可以寻找上一存储单元和下一存储单元。

4. 查找元素慢:链表没有索引,所以查找元素需要从头结点开始依次遍历链表

5. 增删元素快:链表通过指针相连接,增删元素只需要修改指针指向即可,不需要涉及元素的移动。

单链表、双链表概念及基本功能的代码实现:

单链表的基本操作

双链表的基本操作

三、栈

概念:

栈(stack)是一个后进先出(FILO-First In Last Out)的有序列表,允许插入和删除的一端为变化的一端,称为栈顶(Top),另一端为固定的一端,称为栈底(Bottom)。

先放入到栈的元素在栈底,后放入栈的元素为栈顶。栈顶的元素先出,栈底的元素后出。

可以使用单链表和数组的方式实现栈。

单链表:每次插入都将元素插入到第一个位置,每次获取结点都从链表头部获取。

数组:每次插入元素都放在数组的尾部,每次获取元素也从数组尾部获取即可。

栈的概念及基本功能的代码实现:

栈的基本操作

四、队列

概念:

队列(Queue)是一个先进先出(FIFO-First In First Out)的有序列表,主要方法有入队(enqueue /offer)和出队(dequeue /poll)

可以使用单链表和数组的方式实现队列。

单链表:每次入队都将元素插入到链表尾部,每次获取结点都从链表头部获取。

数组:每次入队都将元素按顺序依次添加,每次出队都从数组前面依次出去。

队列的概念及基本功能的代码实现:

队列的基本操作

五、树

树的概念及基本功能的代码实现:

树的基本概念

1. 二叉树

概念:

二叉树是每个节点最多有两个子树的树结构,也就是说树的度为 2。正常情况下,左子树的结点值比父节点小,右子树的结点值比父节点大。二叉树具有很好的搜索性能,可以实现二分查找。

为什么会出现二叉树:因为二叉树,可以使用二叉法,当数据量较大的时候,比链表查询和插入效率更高,因为相同的数据量的情况下,二叉树深度一定比链表的深度小。所以查询的深度就小,所以比较节省时间

二叉树的缺点:二叉树可能会有极端的情况,就是某个节点的深度无限大,这样的二叉树和链表没啥区别,于是为了限制二叉树极端的情况,满足二叉树深度较小的情况,介继而推出了平衡二叉树。

二叉树遍历的方式:

前序遍历:根节点 -> 左节点 -> 右节点

中序遍历:左节点 -> 根节点 -> 右节点

后续遍历:左节点 -> 右节点 -> 根节点

层次遍历:从根节点开始,一层一层往下遍历(采用队列来实现,将根节点放入队列中,然后出列,响应地将其左右子节点放入队列中,以此类推。)

满二叉树和完全二叉树:

满二叉树:每一层的结点数都达到最大值。

完全二叉树:若设二叉树的深度为 k,除第 k 层外,其他各层(1~k-1)的结点数都达到最大个数,第 k 层所有的结点都连续集中在最左边,这就是完全二叉树。

注:完全二叉树的话,所有的结点都连续集中在最左边,也就是如下图所示,右子节点可以没有,但如果右子节点有的话,则左子节点必须存在。下图中如果叶子结点只有 4 结点,5、6、7 结点没有的话,也是完全二叉树。

二叉树的概念及基本功能的代码实现:

二叉树概念及基本功能实现

相关文章
|
存储 机器学习/深度学习 算法
C 408—《数据结构》算法题基础篇—链表(下)
408考研——《数据结构》算法题基础篇之链表(下)。
480 30
|
存储 算法 C语言
C 408—《数据结构》算法题基础篇—链表(上)
408考研——《数据结构》算法题基础篇之链表(上)。
705 25
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】单链表的基本运算(头歌实践教学平台习题)【合集】
本内容介绍了单链表的基本运算任务,涵盖线性表的基本概念、初始化、销毁、判定是否为空表、求长度、输出、求元素值、按元素值查找、插入和删除数据元素等操作。通过C++代码示例详细解释了顺序表和链表的实现方法,并提供了测试说明、通 - **任务描述**:实现单链表的基本运算。 - **相关知识**:包括线性表的概念、初始化、销毁、判断空表、求长度、输出、求元素值、查找、插入和删除等操作。 - **测试说明**:平台会对你编写的代码进行测试,提供测试输入和预期输出。 - **通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了测试通过后的预期输出结果。 开始你的任务吧,祝你成功!
608 5
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
1183 10
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
378 59
|
9月前
|
编译器 C语言 C++
栈区的非法访问导致的死循环(x64)
这段内容主要分析了一段C语言代码在VS2022中形成死循环的原因,涉及栈区内存布局和数组越界问题。代码中`arr[15]`越界访问,修改了变量`i`的值,导致`for`循环条件始终为真,形成死循环。原因是VS2022栈区从低地址到高地址分配内存,`arr`数组与`i`相邻,`arr[15]`恰好覆盖`i`的地址。而在VS2019中,栈区先分配高地址再分配低地址,因此相同代码表现不同。这说明编译器对栈区内存分配顺序的实现差异会导致程序行为不一致,需避免数组越界以确保代码健壮性。
206 0
栈区的非法访问导致的死循环(x64)
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
805 77
232.用栈实现队列,225. 用队列实现栈
在232题中,通过两个栈(`stIn`和`stOut`)模拟队列的先入先出(FIFO)行为。`push`操作将元素压入`stIn`,`pop`和`peek`操作则通过将`stIn`的元素转移到`stOut`来实现队列的顺序访问。 225题则是利用单个队列(`que`)模拟栈的后入先出(LIFO)特性。通过多次调整队列头部元素的位置,确保弹出顺序符合栈的要求。`top`操作直接返回队列尾部元素,`empty`判断队列是否为空。 两题均仅使用基础数据结构操作,展示了栈与队列之间的转换逻辑。
|
算法 调度 C++
STL——栈和队列和优先队列
通过以上对栈、队列和优先队列的详细解释和示例,希望能帮助读者更好地理解和应用这些重要的数据结构。
320 11
|
存储 C++ 索引
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
【数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】初始化队列、销毁队列、判断队列是否为空、进队列、出队列等。本关任务:编写一个程序实现环形队列的基本运算。(6)出队列序列:yzopq2*(5)依次进队列元素:opq2*(6)出队列序列:bcdef。(2)依次进队列元素:abc。(5)依次进队列元素:def。(2)依次进队列元素:xyz。开始你的任务吧,祝你成功!(4)出队一个元素a。(4)出队一个元素x。
509 13
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】