既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
在搞清楚数据结构之前,我们要明白, 什么是结构?
不同数据元素之间不是独立的,而是存在特定的关系,我们将这些关系称为结构。
数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。
1.2 逻辑结构 和 物理结构
按照视点的不同,我们把数据结构分为逻辑结构和物理结构。
1.2.1 逻辑结构
逻辑结构:是指数据对象中数据元素之间的相互关系。
逻辑结构分为以下4中:
1.集合结构
集合结构中的数据元素除了同属于一个集合外,他们之间没有其他关系。
2.线性结构
线性结构中的数据元素之间是一对一的关系。
3.树形结构
树形结构中的数据元素之间存在一对多的层次关系。
4.图形结构
图形结构的数据元素是多对多关系。
从上面的例子中可以看出,逻辑结构是针对具体问题的,是为了解决某个问题,在对问题理解的基础上,选择一个合适的数据结构表示数据元素之间的逻辑关系。
1.2.2 物理结构
说完了逻辑结构,我们再来说说物理结构
物理结构:是指数据的逻辑结构在计算机中的存储形式。
物理结构也被叫做存储结构,数据元素的存储结构形式有2种:顺序存储和链式存储。
1.顺序存储结构
顺序存储结构:是把数据元素存放在地址连续的存储单元里,其数据间的逻辑关系和物理关系是一致的。
顺序存储如同人排队一样,每个人都占据一个空间,数组就是一个典型的顺序存储。
2.链式存储结构
链式存储结构:是把数据元素存放在任意的存储单元里,这组存储单元可以是连续的,也可以是不连续的。
数据元素的存储关系并不能反映其的逻辑关系,因此需要用一个指针来存放数据元素的地址,这样通过地址就可以找到相关联的数据元素的位置。
3.两者的区别
逻辑结构是面向问题的,而物理结构就是面向计算机的,其基本的目表是将数据及其逻辑关系存储到计算机的内存里。
1.3 数据类型
数据类型:是指一组性质相同的值的集合级定义再ci集合上的一些操作的总称。
1.3.1 数据类型定义
数据类型是按照值的不同进行划分的。在高级语言中,每个变量,常亮和表达式都有各自的取值范围。类型就是来说明变量或者表达式的取值范围和所能进行的操作。
说白了就是为了给变量下定义,约束其的范围,和其所能做的操作。
我以c语言举例:
在c语言中,按照取值不同,可以分为两类:
1.原子类型:
是不可以再分解的类型。包含整数、实型、字符型等等。
2.结构类型 :
有若干个类型组合而成的,是可以再分解的。
例如:整形数组是有若干个整形数据组成的。
比如 ,在c语言中变量声明int a ,b, 这就意味着给变量a,b 赋值时只能是int类型的,不能超过int的取值范围 ,变量a和b之间的运算也只能是int类型所允许的运算。
1.3.2 抽象数据类型
为了把各种程序语言转化成底层语言,我们对已有的的数据类型进行抽象,就有了抽象数据类型。
那么,抽象是啥呢?
抽象是指抽取出事物具有的普遍性的本质。
抽象数据类型(Abstract Data type , ADT) :
一个数据模型及定义在该模式上的一组操作
实际上,抽象数据类型体现了程序设计中问题分解、抽象和信息隐藏的特性。抽象数据类型把实际生活中的问题分为了多个小规模的且容易处理的问题,然后建立一个计算机能处理的数据模型,并把每个功能模块的实现细节作为一个独立的单元,从而使具体实现过程隐藏起来。
描述抽象数据类型的标准格式:
ADT 抽象数据类型名
Data
数据元素之间逻辑关系的定义
Operation
操作1
初始条件
操作结果描述
操作2
.........
操作n
........
endADT
总结与后记
今天,我们学习了数据结构的一些相关概念,给出了数据结构的定义,数据结构是相互之间存一种或多种特定关系的数据元素集合。同样是结构,从不同的角度来讨论,会有不同的分类。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
需要这份系统化的资料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618668825)**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!