c语言中数据结构是什么?常见数据结构有哪些?

c语言中,数据结构是指相互之间存在一种或多种特定关系的数据元素的集合,它是计算机存储、组织数据的方式;常见数据结构有:线性数据结构(数组、链表、栈、队列和线性表)、树形结构(二叉树、完全二叉树、二叉查找树、堆)、图形结构(有向图和无向图)。

c语言中数据结构是什么?常见数据结构有哪些?

本教程操作环境:windows7系统、c99版本、Dell G3电脑。

什么是数据结构呢?

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

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

立即学习“C语言免费学习笔记(深入)”;

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

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

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

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

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

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

(1)数组和链表

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

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

c、数组和链表的区别:

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

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

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

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

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

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

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

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

1.jpg

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

2.jpg

b、队列:只允许在序列两端进行操作,一般队列也被称为先进先出的线性结构
循环队列:采用顺序存储结构的队列,需要按队列可能的最大长度分配存储空空,其类型定义如下:

3.jpg

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

4.jpg

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

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

5.jpg

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

单链表:

6.jpg

双向链表:

7.jpg

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

顺序表:

 优点:在顺序表中,逻辑中相邻的两个元素在物理位置上也相邻,查找比较方便,存取任一元素的时间复杂度都为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)

8.jpg

b、采用链式存储结构:

二叉链表:

9.jpg

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

10.jpg

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

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

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

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

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

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

11.jpg

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

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

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

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

12.jpg

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

(8)B树

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

教程推荐:《c语言教程视频》

以上就是c语言中数据结构是什么?常见数据结构有哪些?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1434736.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 10:06:09
下一篇 2025年12月17日 10:06:19

相关推荐

  • c语言的输入输出语句有哪些?

    c语言的输入输出语句有:“getchar(void);”和“putchar(int c);”、“scanf(“格式控制字符串”,地址列表);”和“printf(“格式控制字符串”,输出列表);”、“gets()”和“puts()”等等。 教程推荐:《c…

    好文分享 2025年12月17日
    000
  • c语言是高级语言吗?

    c语言是高级语言。高级语言是一种独立于机器,面向过程或对象的语言;它并不是特指的某一种具体的语言,而是包括很多编程语言,如流行的java,c,c++,C#,pascal,python,lisp,prolog,FoxPro,中文版的C语言等。 c语言是高级语言。 高级语言(High-level pro…

    2025年12月17日
    000
  • C语言标识符有哪三类

    C语言标识符有关键字、用户标识符、预定义标识符三类。C语言规定,标识符只能由字母、数字和下划线组成,并且第一个字符必须是字母或下划线,不能是数字。 C语言中的标识符可分为关键字、用户标识符、预定义标识符三类。 (学习视频分享:java视频教程) C语言规定,标识符只能由字母(A~Z, a~z)、数字…

    2025年12月17日
    000
  • C语言中字符串的结束标志是什么

    C语言中字符串的结束标志是【’’】。C语言中没有专门的字符串变量,通常用一个字符数组来存放一个字符串,字符串总是以【’’】作为结束符。 ‘’就是8位的00000000,因为字符类型中并没有对应的这个字符,所以这么写。&#8217…

    2025年12月17日
    000
  • c语言是一种什么的程序设计语言?

    C语言是一门面向过程的、抽象化的通用计算机程序设计语言,广泛应用于底层开发;它可以作为系统设计语言,编写工作系统应用程序,也可以作为应用程序设计语言,编写不依赖计算机硬件的应用程序。 教程推荐:《c语言教程视频》 C语言是一门面向过程的、抽象化的通用计算机程序设计语言,广泛应用于底层开发。C语言能以…

    2025年12月17日
    000
  • C语言的三种基本程序结构是什么

    C语言的三种基本程序结构是:1、顺序结构,如表达式语句、函数调用语句、复合语句;2、选择结构,如if语句;3、循环结构,如for语句、while语句、do while语句。 一、顺序结构 表达式语句、空语句、函数调用语句、复合语句 (相关视频分享:java视频教程) 程序举例: 立即学习“C语言免费…

    2025年12月17日
    000
  • C语言中的指针有什么作用

    C语言中的指针的作用是:通过指针不仅可以对数据本身,还可以对存储数据的变量地址进行操作。指针就是内存地址,指针变量是用来存放内存地址的变量。 指针定义: 指针,是C语言中的一个重要概念及其特点,也是掌握C语言比较困难的部分。指针也就是内存地址,指针变量是用来存放内存地址的变量,不同类型的指针变量所占…

    2025年12月17日
    000
  • c语言规定在一个源程序中main函数的位置是什么?

    c语言规定在一个源程序中main函数的位置可以是任意的;因为一个C程序总是从main函数开始执行,并在main函数中结束,不论main函数在整个过程中的位置如何。 一个c程序有且仅有一个main函数,除main函数之外可以有若干个其它的函数,每个函数实现某一特定的操作。 C语言规定,在一个源程序中,…

    2025年12月17日
    000
  • c语言用什么软件编写?

    编写c语言的软件有:Microsoft Visual C++ 、Microsoft Visual Studio、 DEV C++、Code::Blocks、Borland C++、WaTCom C++、C-Free、Win-TC等等。 C语言是一门历史很长的编程语言,其编译器和开发工具也多种多样,其…

    2025年12月17日 好文分享
    000
  • c语言源程序结构是怎样的?

    一个C语言源程序可以由一个或多个源文件组成,而每个源文件可由一个或多个函数组成;一个源程序不论由多少个文件组成,都有一个且只能有一个main函数,即主函数;定义函数必须指定 4 个元素:返回类型、函数名、圆括号内的形参表(可为空)和函数体。 教程推荐:《c语言教程视频》 一个C语言源程序至少一个有m…

    2025年12月17日
    000
  • vc++6.0怎么新建c语言文件

    vc++6.0新建c语言文件的方法:首先打开visual,并选择新建;然后选择工程,并选择“Win 32 Console Application”;最后创建一个C语言程序即可。 用VC++6.0简单创建C语言文件教程 先找到桌面上的图标双击打开 打开后点左上角文件,然后新建。 或者快捷键ctrl+N…

    2025年12月17日 好文分享
    000
  • C语言怎么合并两个有序链表

    C语言合并两个有序链表的方法:拼接指定的两个有序链表的所有节点即可。例如两个有序链表分别为【1->2->4】和【1->3->4】,合并后的有序链表为【1->1->2->3->4->4】。 具体方法: 将两个有序链表合并为一个新的有序链表并返回。新…

    2025年12月17日
    000
  • c语言for循环如何打印菱形

    c语言for循环打印菱形的方法:使用两个for循环,实现条件判断,代码为【int i,j;for(i=0; i c语言for循环打印菱形的方法: 方法一(以循环为主打印) #include void print(int n) { int i,j; for(i=1; i<=n; i++) { f…

    2025年12月17日
    000
  • 如何用c语言编写动态烟花

    用c语言编写动态烟花的方法:首先绘制菜单界面显示文字;然后设置烟花有上升阶段和爆炸阶段,定义烟花和烟花弹结构体;最后初始化数据,加载资源贴图,随机发射数目随机。 用c语言编写动态烟花的方法: 效果展示 动态图 总体框架 /***************************************…

    2025年12月17日 好文分享
    000
  • C语言如何编程生日快乐代码

    C语言编程生日快乐代码的方法:首先要按【CTRL+R】键,cmd进入命令行,输入pip install turtle安装第三方库;然后打开C语言编辑器,将相关代码复制进去;最后按快捷键F5进行保存且执行即可。 C语言编程生日快乐代码的方法: #include #include #include #d…

    2025年12月17日
    000
  • c语言如何实现玫瑰花

    c语言实现玫瑰花的方法:首先定义全局变量,并定义结构体;然后设置输出花柄、花柄、绿叶、花萼;最后创建绘图窗口,输出完整花朵。 c语言实现玫瑰花的方法: #include #include ?#include #include #include #pragma comment(lib,”winmm.l…

    2025年12月17日
    000
  • return在c语言中是什么意思

    return在c语言中的意思为“返回”。return表示把程序流程从被调函数转向主调函数并把表达式的值带回主调函数,实现函数值的返回,返回时可附带一个返回值,由return后面的参数指定。 函数是C语言的基本构件,一个C程序可以由一个主函数和若干个子程序函数构成,由主函数调用其它子程序函数,其他子程…

    2025年12月17日
    000
  • c语言程序的基本单位是什么

    c语言程序的基本单位是函数,函数是C程序的基本组成单位,一个C语言程序中仅有一个main函数,除main函数之外可以有若干个其它的函数,每个函数实现某一特定的操作。 推荐:《C语言教程》 C语言程序是由函数构成的,函数是C程序的基本组成单位,一个C语言程序中仅有一个main()函数,除main函数之…

    2025年12月17日
    000
  • 用c语言编写的代码程序是什么?

    用c语言编写的代码程序是一个源程序。源程序是指未编译的按照一定的程序设计语言规范书写的文本文件,是一系列人类可读的计算机语言指令。 教程推荐:《c语言教程视频》 源程序是指未编译的按照一定的程序设计语言规范书写的文本文件,是一系列人类可读的计算机语言指令。  在现代程序语言中,源代码可以是以书籍或者…

    2025年12月17日
    000
  • c语言编译后生成什么文件

    c语言编译后生成“.OBJ”的二进制文件。C语言源程序经过C语言编译程序编译之后,生成一个后缀为“.OBJ”的二进制文件,最后还要由称为“连接程序”的软件把此“.OBJ”文件与c语言提供的各种库函数连接在一起,生成一个后缀“.EXE”文件。 C语言源程序经过C语言编译程序编译之后,生成一个后缀为“.…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信