Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >C语言中都有哪些常见的数据结构你都知道几个??

C语言中都有哪些常见的数据结构你都知道几个??

作者头像
用户6754675
修改于 2020-09-28 06:23:27
修改于 2020-09-28 06:23:27
6880
举报
文章被收录于专栏:嵌入式单片机嵌入式单片机

上次在面试时被面试官问到学了哪些数据结构,那时简单答了栈、队列/(ㄒoㄒ)/~~其它就都想不起来了,今天有空整理了一下几种常见的数据结构,原来我们学过的数据结构有这么多~

首先,先来回顾下C语言中常见的基本数据类型吧O(∩_∩)O

C语言的基本数据类型有:整型int,浮点型float,字符型char等等

添加描述

那么,究竟什么是数据结构呢?

数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合

大部分数据结构的实现都需要借助C语言中的指针和结构体类型

下面,进入今天的重点啦O(∩_∩)O几种常见的数据结构

(1)线性数据结构:元素之间一般存在元素之间存在一对一关系,是最常用的一类数据结构,典型的有:数组、栈、队列和线性表

(2)树形结构:结点间具有层次关系,每一层的一个结点能且只能和上一层的一个结点相关,但同时可以和下一层的多个结点相关,称为“一对多”关系,常见类型有:树、堆

(3)图形结构:在图形结构中,允许多个结点之间相关,称为“多对多”关系

下面分别对这几种数据结构做一个简单介绍:

1、线性数据结构:典型的有:数组、栈、队列和线性表

(1)数组和链表

a、数组:存放着一组相同类型的数据,需要预先指定数组的长度,有一维数组、二维数组、多维数组等

b、链表:链表是C语言中一种应用广泛的结构,它采用动态分配内存的形式实现,用一组任意的存储单元存放数据元素链表的,一般为每个元素增设指针域,用来指向后继元素

c、数组和链表的区别:

从逻辑结构来看:数组必须事先定义固定的长度,不能适应数据动态地增减的情况;链表动态地进行存储分配,可以适应数据动态地增减的情况,且可以方便地插入、删除数据项(数组中插入、删除数据项时,需要移动其它数据项)

从内存存储来看:(静态)数组从栈中分配空间(用NEW创建的在堆中), 对于程序员方便快速,但是自由度小;链表从堆中分配空间, 自由度大但是申请管理比较麻烦

从访问方式来看:数组在内存中是连续存储的,因此,可以利用下标索引进行随机访问;链表是链式存储结构,在访问元素的时候只能通过线性的方式由前到后顺序访问,所以访问效率比数组要低

(2)栈、队列和线性表:可采用顺序存储和链式存储的方法进行存储

顺序存储:借助数据元素在存储空间中的相对位置来表示元素之间的逻辑关系

链式存储:借助表示数据元素存储地址的指针表示元素之间的逻辑关系

a、栈:只允许在序列末端进行操作,栈的操作只能在栈顶进行,一般栈又被称为后进先出或先进后出的线性结构

顺序栈:采用顺序存储结构的栈称为顺序栈,即需要用一片地址连续的空间来存储栈的元素,顺序栈的类型定义如下:

添加描述

链栈:采用链式存储结构的栈称为链栈:

添加描述

b、队列:只允许在序列两端进行操作,一般队列也被称为先进先出的线性结构

循环队列:采用顺序存储结构的队列,需要按队列可能的最大长度分配存储空空,其类型定义如下:

添加描述

链队列:采用链式存储结构的队列称为链队列,一般需要设置头尾指针只是链表的头尾结点:

添加描述

c、线性表:允许在序列任意位置进行操作,线性表的操作位置不受限制,线性表的操作十分灵活,常用操作包括在任意位置插入和删除,以及查询和修改任意位置的元素

顺序表:采用顺序存储结构表示的线性表称为顺序表,用一组地址连续的存储单元一次存放线性表的数据元素,即以存储位置相邻表示位序相继的两个元素之间的前驱和后继关系,为了避免移动元素,一般在顺序表的接口定义中只考虑在表尾插入和删除元素,如此实现的顺序表也可称为栈表:

添加描述

线性表:一般包括单链表、双向链表、循环链表和双向循环链表

单链表:

添加描述

双向链表:

添加描述

线性表两种存储结构的比较:

顺序表:

优点:在顺序表中,逻辑中相邻的两个元素在物理位置上也相邻,查找比较方便,存取任一元素的时间复杂度都为O(1)

缺点:不适合在任意位置插入、删除元素,因为需要移动元素,平均时间复杂度为O(n)

链表:

优点:在链接的任意位置插入或删除元素只需修改相应指针,不需要移动元素;按需动态分配,不需要按最大需求预先分配一块连续空空

缺点:查找不方便,查找某一元素需要从头指针出发沿指针域查找,因此平均时间复杂度为O(n)

2、树形结构:结点间具有层次关系,每一层的一个结点能且只能和上一层的一个结点相关,但同时可以和下一层的多个结点相关,称为“一对多”关系,常见类型有:树、堆

(1)二叉树:二叉树是一种递归数据结构,是含有n(n>=0)个结点的有限集合,二叉树具有以下特点:

二叉树可以是空树;二叉树的每个结点都恰好有两棵子树,其中一个或两个可能为空;二叉树中每个结点的左、右子树的位置不能颠倒,若改变两者的位置,就成为另一棵二叉树

(2)完全二叉树:从根起,自上而下,自左而右,给满二叉树的每个结点从1到n连续编号,如果每个结点都与深度为k的满二叉树中编号从1至n的结点一一对应,则称为完全二叉树

a、采用顺序存储结构:用一维数组存储完全二叉树,结点的编号对于与结点的下标(如根为1,则根的左孩子为2i=21=2,右孩子为2i+1=21+1=2)

添加描述

b、采用链式存储结构:

二叉链表:

添加描述

三叉链表:它的结点比二叉链表多一个指针域parent,用于执行结点的双亲,便于查找双亲结点

添加描述

两种存储结构比较:对于完全二叉树,采用顺序存储结构既能节省空间,又可利用数组元素的下标值确定结点在二叉树中的位置及结点之间的关系,但采用顺序存储结构存储一般二叉树容易造成空间浪费,链式结构可以克服这个缺点

(3)二叉查找树:二叉查找树又称二叉排序树,或者是一课空二叉树,或者是具有如下特征的二叉树:

a、若它的左子树不空,则左子树上所有结点的值均小于根结点的值

b、若它的右子树不空,则右子树上所有结点的值均大于根结点的值

c、它的左、右子树也分别是二叉查找树

(4)平衡二叉树:平衡二叉查找树简称平衡二叉树,平衡二叉树或者是棵空树,或者是具有下列性质的二叉查找树:它的左子树和右子树都是平衡二叉树,且左子树和右子树的高度之差的绝对值不超过1

添加描述

平衡二叉树的失衡及调整主要可归纳为下列四种情况:LL型、RR型、LR型、RL型

(5)树:树是含有n(n>=0)个结点的有限集合,在任意一棵非空树种: a、有且仅有一个特定的称为根的结点

b、当n>1时,其余结点可分为m(m>0)个互不相交的有限集T1,T2,…,Tm,其中每一个集合本身又是一棵树,并且T1,T2,…,Tm称为根的子树

(6)堆:堆是具有以下特性的完全二叉树,其所有非叶子结点均不大于(或不小于)其左右孩子结点。若堆中所有非叶子结点均不大于其左右孩子结点,则称为小顶堆(小根堆),若堆中所有非叶子结点均不小于其左右孩子结点,则称为大顶堆(大根堆)

添加描述

(7)并查集:并查集是指由一组不相交子集所构成的集合,记作:S={S1,S2,S3,…,Sn}

(8)B树

3、图形结构:在图形结构中,允许多个结点之间相关,称为“多对多”关系,可分为有向图和无向图

一些相关的视频资料便于大家学习

C语言与数据结构的经典实战案例

http://www.makeru.com.cn/live/5413_2014.html?s=45051

结构体普及与应用

http://www.makeru.com.cn/live/5413_1909.html?s=45051

C语言玩转链表

http://www.makeru.com.cn/live/1392_338.html?s=45051

C高级之结构体

http://www.makeru.com.cn/live/1392_656.html?s=45051

循环链表及线性表的应用

http://www.makeru.com.cn/course/details/1902?s=45051

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
作者已关闭评论
暂无评论
推荐阅读
编辑精选文章
换一批
C语言中都有哪些常见的数据结构你都知道几个??
上次在面试时被面试官问到学了哪些数据结构,那时简单答了栈、队列/(ㄒoㄒ)/~~其它就都想不起来了,今天有空整理了一下几种常见的数据结构,原来我们学过的数据结构有这么多~
用户6754675
2020/03/31
3.9K0
【数据结构】二叉树的存储结构
与前面我们学习的线性表不同,在树这种新的数据结构中,数据与数据之间呈现的是一对多和多对一的关系,在逻辑上就像一棵树一样从树根开始往外发散式的分布,因此我们将数据之间呈现的这种逻辑关系称为树形结构。
蒙奇D索隆
2024/09/07
1650
【数据结构】二叉树的存储结构
java实现数据结构
一.数据结构和算法简介 数据结构是指数据在计算机存储空间中的安排方式,而算法时值软件程序用来操作这些结构中的数据的过程. 二. 数据结构和算法的重要性 几乎所有的程序都会使用到数据结构和算法,即便是最简单的程序也不例外.比如,你希望打印出学生的名单,这个程序使用一个数组来存储学生名单,然后使用一个简单的 for循环来遍历数组,最后打印出每个学生的信息. 在这个例子中数组就是一个数据结构,而使用for循环来遍历数组,则是一个简单的算法.可见数据结构和算法是构成程序的灵魂所在,而且也有人提出数据结构+算法=程序. 简单算法
海仔
2019/08/06
1K0
数据结构基础 (代码效率优化, 线性表, 栈, 队列, 数组,字符串,树和二叉树,哈希表)
具有增删困难、查找容易的特点,可以在任意位置增删数据,所以数组的增删操作会更为多样。
RendaZhang
2020/09/08
9080
数据结构基础 (代码效率优化, 线性表, 栈, 队列, 数组,字符串,树和二叉树,哈希表)
数据结构基础题复习
分析:看下图,表中每一行(相当于结点中每一个结点)就是一个数据元素;数据元素中的每一项,比如张三的数学分析是90分就是一个数据项;整个表格是一个数据对象,它代表的都是学生的信息(具有相同性质的数据元素的集合)。
Maynor
2024/05/26
1770
数据结构基础题复习
数据结构-概述
线性表是具有相同数据类型的n个数据元素的有限序列。 逻辑上,每个元素有且只有一个直接前驱,有且只有一个直接后继(表头表尾元素例外)
千灵域
2022/06/17
1.6K0
数据结构-概述
[数据结构]二叉树概念
树是一种非线性的数据结构,它是由n(n>=0)个有限节点组成一个具有有限关系的集合。把它叫做树,是因为它看起来像一颗倒挂的树,也就是它是根朝上,而叶朝下的。
IT编程爱好者
2023/04/12
2890
[数据结构]二叉树概念
《拉钩课程 — 重学数据结构与算法》学习笔记
3、复杂度是一个关于输入数据量 n 的函数。假设你的代码复杂度是 f(n),那么就用个大写字母 O 和括号,把 f(n) 括起来就可以了,即 O(f(n))。
JMCui
2021/12/09
4960
《拉钩课程 — 重学数据结构与算法》学习笔记
【数据结构】数据结构高手进阶:并查集VS森林,谁才是集合操作的真神?
集合这种逻辑结构是指在集合中的数据元素之间除了同一个集合外,没有其它的关系,如下图所示:
蒙奇D索隆
2025/03/21
650
【数据结构】数据结构高手进阶:并查集VS森林,谁才是集合操作的真神?
数据结构初探
数组是可以再内存中连续存储多个元素的结构,在内存中的分配也是连续的,数组中的元素通过数组下标进行访问,数组下标从0开始
猿_人类
2019/10/15
4970
《王道》数据结构笔记整理2022级_数据结构笔记整理
1.数据:数据是信息的载体,是描述客观事物属性的数、字符以及所有能输入到计算机中并被程序识别和处理的符号的集合。
全栈程序员站长
2022/09/22
3.1K0
《王道》数据结构笔记整理2022级_数据结构笔记整理
数据结构 严慰敏(C语言版第2版)【习题答案】
1.简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型。
MIKE笔记
2023/03/22
1.9K0
数据结构 严慰敏(C语言版第2版)【习题答案】
数据结构笔记(二)
栈是限定仅在表尾进行插入和删除操作的线性表。 队列是只允许在一段进行插入操作、而在另一端进行删除操作的线性表。
一点儿也不潇洒
2018/08/07
3120
软考中级之数据库系统工程师笔记总结(二)数据结构与算法
​ 特点是物理位置上的邻接关系来表示结点的逻辑关系,具有可以随机存取表中的任一结点的,但插入删除不方便
Maynor
2024/05/26
1470
软考中级之数据库系统工程师笔记总结(二)数据结构与算法
数据结构的树存储结构
之前介绍的所有的数据结构都是线性存储结构。本章所介绍的树结构是一种非线性存储结构,存储的是具有“一对多”关系的数据元素的集合。
zhangjiqun
2024/12/14
1850
数据结构的树存储结构
讲透学烂二叉树(四):二叉树的存储结构—建堆-搜索-排序
数据结构是组织数据的方式,例如树,但是要注意数据结构有两种形式:逻辑结构和存储结构,这两种结构在表示一种数据结构的时候不一定完全相同的,逻辑结构是我们分析数据结构和算法的主要形式,而存储结构则是数据结构在内存中的存储形式。
周陆军
2021/08/15
1.2K0
数据结构与算法(1)
1、数据:数据的基本单位是数据元素。数据元素可由一个或多个数据项组成。数据项是数据的不可分割的最小单位
ellipse
2019/08/16
2910
软件设计(十一)数据结构(上)
2)线性表的 链式存储:指用节点来存储数据元素,节点的空间可以是连续的,也可以是不连续的,因此存储数据元素的同时必须存储元素之间的逻辑关系。节点空间只有在需要的时候才申请,无须事先分配。
用户9919783
2023/02/28
3940
软件设计(十一)数据结构(上)
【五分钟】001-数据结构概论
数据元素(Data Element) 是数据的基本单位,有时数据元素也称为元素、节点、顶点、记录。
痴者工良
2021/04/26
5320
数据结构考研面试被问的问题_考研程序设计与数据结构
1. 顺序存储结构 ——把数据元素存放在地址连续的存储单元中,其数据间的逻辑关系和物理关系是一致的。
全栈程序员站长
2022/11/04
6770
数据结构考研面试被问的问题_考研程序设计与数据结构
推荐阅读
相关推荐
C语言中都有哪些常见的数据结构你都知道几个??
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档