数据结构的定义(下):结构是什么

简介: 结构?怎一看,有建筑结构,有书本目录结构等等,建筑结构表示建筑物内在物的各个组成部分的关系,目录目录结构表示书中每一章节的顺序,那么数据结构中的结构有表示什么呐?我们来看看官方定义:相互之间存在一种或多种特定关系的数据元素的集合。顾名思义,数据相互之间的集合,当然肯定是两个或两个以上数据的关系,就一个数据,那来的关系,在计算机中,每个数据元素都是有意义的,不存在孤立的,杂乱无序的数据元素,每个数据之间都是有一定的内在联系。每了编写出优秀的程序,我们必须处理好数据元素的特性及要处理对象之间的关系,这也是研究数据结构的真正意义所在。那么这些特定关系中都有哪些关系呐?

接上一节我们讲到什么是数据,不记得同学,可看看上一节的内容。我们今天来讲数据结构中的结构的定义。

结构?怎一看,有建筑结构,有书本目录结构等等,建筑结构表示建筑物内在物的各个组成部分的关系,目录目录结构表示书中每一章节的顺序,那么数据结构中的结构有表示什么呐?

我们来看看官方定义:相互之间存在一种或多种特定关系的数据元素的集合。顾名思义,数据相互之间的集合,当然肯定是两个或两个以上数据的关系,就一个数据,那来的关系,在计算机中,每个数据元素都是有意义的,不存在孤立的,杂乱无序的数据元素,每个数据之间都是有一定的内在联系。

每了编写出优秀的程序,我们必须处理好数据元素的特性及要处理对象之间的关系,这也是研究数据结构的真正意义所在。那么这些特定关系中都有哪些关系呐?

一、逻辑结构与物理结构

按照常规分类,我们把数据结构分为逻辑结构和物理结构,这个跟我们把事物分抽象跟具体一样。

结构是非常重要的,它既能节省空间又能提高计算机的运算速度,举个例子:假如给大家提供一个箱子用来装衣服,男同学不事先叠好衣服,直接把衣服丢进去,女同学先把衣服按大小,样式,相同款式的衣服叠起来,然后按照事先考虑好的摆放顺序装进箱子里,最后我看看,同样的空间,女同学装衣服的数量远远大于男同学,这也是一个结构的思维。

1.1、逻辑结构

定义:逻辑结构是指数据对象中数据元素之间的相互关系。,这个跟我们高中学习的集合等数学学到知识类,我们把逻辑结构分为四种:集合结构、线性结构、树形结构、图形结构。

(1) 集合结构

试想一下我们以前用到过的火柴(可能现在的90后或00后很少见过火柴,都是用打火机比较多),这些火柴看起来都一样的,没有任何区分,它们没有任何关系,每一根都是平等的。

这就是我们现在说的集合:集合结构中的数据元素除了同属于一个集合外,它们之间没有其他关系。每一个数据都是“平等”的,它们的共同属性是“同属于一个集合”。这个跟数学中的集合类似。如下图(圆内的每个数字都是无序平等的分布在圆内):

(2) 线性结构

线性结构在我们生活中经常遇到,比如我们在排队,它就是一种线性的结构

线性结构中的数据元素之间是一对一的关系。一前一后就是排队的关系。

(3) 树形结构

树形结构在我们生活中也比较常见,比如公司的组织关系,学校的组织关系。

上图中部门或员工之间存在一对或一对多的层次关系,层次关系是树形结构的一种较为重要的概念,其次是一对多,到处我们引出了数据结构中的树形结构的概念:树形结构中的数据元素之间存在一种一对多的层次关系

(4) 图形结构

在开始介绍图形结构前,我们来看看邓超跟孙俪的电影关系图

从图中我们可以看到邓超跟孙俪两人是夫妻关系,他们一起演过电影,又有各自主演的电影。

这种关系就是一个比较典型的图形结构,图形结构在图谱中比较流行使用,它是一种多对多的关系,它的定义是:图形结构的数据元素是多对多的关系

在画数据结构的逻辑结构时,需要注意两点:

  • 每个数据元素都是一个独立节点,用圆圈表示
  • 元素与元素之间的逻辑关系用连线表示,如果有方向,可以使用箭头表示、

1.2、物理结构

上面介绍了逻辑结构,现在我们来物理结构的定义(有些资料也称为存储结构,都是一回事,大家不要太在意)。物理结构:是指数据的逻辑结构在计算机中的存储形式

在计算机中,以何种方式把数据存储到计算机中的存储器,这就涉及到物理几个,存储器我们可以很好理解,比如硬盘,软盘,光盘,U盘等外部存储器,这些通常用户文件结构来描述存储结构。

数据的存储结构正确反映了数据元素之间的逻辑关系,这才是最为关键的,

数据元素的存储结构主要分为两种形式:顺序存储和链式存储。

(1) 顺序式存储结构

顺序式存储结构比较好理解一些:数据元素放在地址连续的存储单元里,数据的逻辑关系和物理关系是一样的。就跟围棋盘子一样。

这种结构相对来说比较简单,就是排队占位,都按照固定的顺序排好,每个人占一个空间,不插队。

(2) 链式存储结构

顺序式存储结构要求数据元素按顺序排序,不插队,不离队,一个处理完,直接到下一个,但实际排队的时候,总有人不按规矩来,排队离队的情况总会存在。这情况也在计算机中存在,有些数据需要删除也有需要插入的数据,这种情况顺序式存储结构是无法满足这个需求的,这时就引入了链式存储结构。

链式存储结构定义:链式存储结构把数据元素存放在任意的存储单元里,这组存储单元可以是连续的,也可以是不连续的。我们来看看下图。

在链式存储结构中,数据元素的存储关系并不能反映其逻辑关系,这时候需要一个指针(规定起点跟终点),数据元素只关心与我相关的元素就可以,比如前面跟后面(后面的都不需要太关心),这样通过指针指定的地址就可以找到相关联数据元素的位置。

这样看来,链式存储比顺序式存储灵活很多,同样的空间,顺序存储需要事先把所有的位置规划好,每个元素都要按照已经标注好的位置存放,是在几号位置就在几号位置,都已经安排好的。而链式存储只需要第一个元素知道了位置,其他的元素只需要知道前面的元素及对应的指针就行,存储的位置地址会告诉元素。

综上,逻辑结构是面向问题的,是为了接近问题,物理结构是面向计算机的,基本目标是将数据集及其逻辑关系存储到计算机的内存中。

二、抽象数据类型

2.1、数据类型

第一次接触抽象事物时都比较难以理解的,我们要需要多想象一下,多思考,每个名词的定义都是具备一定的规律,不会凭空想象的,比如我们定义书,定义动物,定义白电,黑电都是有一定的规划归类的。在数据类型中,我们也是这样定义的:是指一组性质相同的值的集合及定义在此集合上的一些操作的总称。

相同性质的集合及操作,非单个数据元素,在数据结构中,数据类型是按照值的不同进行划分的。在高级语言中,每个变量、常量和表达式都有各自的取值范围。类型就是用来说明变量或表达式的取值范围,和所能进行的操作。

当时设计计算机语言的前辈,为什么要考虑数据类型呐,搞那么复杂干嘛,就用一个名称来表示数字,一个符合表示操作不更好吗?现实中真的可以吗?我们来看看一个案例?

大家都想要住房子,当然越大越好,不同的人经济实力不一样,有钱人不可能跟我们黎民百姓一样去住平房,房地产商根据这种情况,就推出来满足不同阶层的房子,有普通上班族的普通商品房、有满足富豪的别墅,有单间,有错层的;有一百多平的,也有几十平的,甚至在一线城市还出现胶囊公寓。。这样就满足了不同人的需要。

在计算机中,内存也不是无限大的,假如你要计算简单的加减法,显然你开辟大量的内存空间,那就大材小用,浪费资源,

于是乎,我们根据数据进行分类,分出来多种数据类型。

java是强类型语言,所以java对于数据类型的规范会相对严格。本质上讲讲数据类型分为两种:

  • 基本类型:简单数据类型不能简化的、内置的数据类型,由编程语言本身定义的,表示真实的数字、字符和整数。
  • 引用类型:Java本身不支持C++中的结构(struct)或联合(union)数据类型,它的复合数据类型一般都是通过类或接口进行构造,类提供了捆绑数据和方法的方式,同时可以针对程序外部进行信息隐藏

2.2、基本类型

Java语言提供了八种基本类型。六种数字类型(四个整数型,两个浮点型),一种字符类型,还有一种逻辑型(布尔型)。俗称四类八种:

  • 第一类:四种整数型 byte short int long
  • 第二类:两种浮点型 float double
  • 第三类:一种逻辑型 boolean(它只有两个值可取true false)
  • 第四类:一种字符型 char

在栈中可以直接分配内存的数据是基本数据类型。

java中默认的整数类型是int类型,如果要定义为float型,则要在数值后加上l或L; 默认的浮点型也是双精度浮点,如果要定义为float型,则要在数值后加上f或F。

2.3、引用类型

在 Java 中一切都被视为了对象,但是我们操作的标识符实际上是对象的一个引用(reference)

简单的说,引用其实就像是一个对象的名字或者别名 (alias),一个对象在内存中会请求一块空间来保存数据,根据对象的大小,它可能需要占用的空间大小也不等。访问对象的时候,我们不会直接是访问对象在内存中的数据,而是通过引用去访问。引用也是一种数据类型,我们可以把它想象为类似 C++ 语言中指针的东西,它指示了对象在内存中的地址——只不过我们不能够观察到这个地址究竟是什么。

如果我们定义了不止一个引用指向同一个对象,那么这些引用是不相同的,因为引用也是一种数据类型,需要一定的内存空间(stack,栈空间)来保存。但是它们的值是相同的,都指示同一个对象在内存(heap,堆空间)的中位置.

Java 对引用的概念进行了扩充,将引用分为了:强引用(Strong Reference)、软引用(Soft Reference)、弱引用(Weak Reference)、虚引用(Phantom Reference)4 种,这 4 种引用的强度依次减弱。在这里我们就不展开讨论了。

三、今日总结

今天我们讨论了数据结构中结构的定义,我们需要掌握到什么是结构,什么是数据类型的知识,在以后需要用到的时候,我们能很好为归类及应用到它,

好了,今天就先介绍到这里,明天我们来讲解一下:数据结构俗话说—数据结构与算法的区别。

目录
相关文章
|
2月前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
104 16
|
3月前
|
存储 编译器 C++
【初阶数据结构】掌握二叉树遍历技巧与信息求解:深入解析四种遍历方法及树的结构与统计分析
【初阶数据结构】掌握二叉树遍历技巧与信息求解:深入解析四种遍历方法及树的结构与统计分析
|
3月前
探索顺序结构:栈的实现方式
探索顺序结构:栈的实现方式
|
3月前
|
存储 算法
【数据结构】二叉树——顺序结构——堆及其实现
【数据结构】二叉树——顺序结构——堆及其实现
|
4月前
|
存储 算法 C语言
数据结构基础详解(C语言): 二叉树的遍历_线索二叉树_树的存储结构_树与森林详解
本文从二叉树遍历入手,详细介绍了先序、中序和后序遍历方法,并探讨了如何构建二叉树及线索二叉树的概念。接着,文章讲解了树和森林的存储结构,特别是如何将树与森林转换为二叉树形式,以便利用二叉树的遍历方法。最后,讨论了树和森林的遍历算法,包括先根、后根和层次遍历。通过这些内容,读者可以全面了解二叉树及其相关概念。
|
4月前
|
存储 算法 C语言
数据结构基础详解(C语言):单链表_定义_初始化_插入_删除_查找_建立操作_纯c语言代码注释讲解
本文详细介绍了单链表的理论知识,涵盖单链表的定义、优点与缺点,并通过示例代码讲解了单链表的初始化、插入、删除、查找等核心操作。文中还具体分析了按位序插入、指定节点前后插入、按位序删除及按值查找等算法实现,并提供了尾插法和头插法建立单链表的方法,帮助读者深入理解单链表的基本原理与应用技巧。
731 6
|
4月前
|
存储 机器学习/深度学习 C语言
数据结构基础详解(C语言): 树与二叉树的基本类型与存储结构详解
本文介绍了树和二叉树的基本概念及性质。树是由节点组成的层次结构,其中节点的度为其分支数量,树的度为树中最大节点度数。二叉树是一种特殊的树,其节点最多有两个子节点,具有多种性质,如叶子节点数与度为2的节点数之间的关系。此外,还介绍了二叉树的不同形态,包括满二叉树、完全二叉树、二叉排序树和平衡二叉树,并探讨了二叉树的顺序存储和链式存储结构。
|
4月前
MITK中的数据结构和常量定义
本文介绍了MITK中的数据结构、反射机制、常量定义、DataNode类和类宏定义,包括多图映射、反射接口、事件宏和属性列表等高级特性。
|
5月前
|
存储
数据结构中的 线性结构和非线性结构
这篇文章介绍了数据结构中的线性结构和非线性结构,其中线性结构包括顺序存储结构和链式存储结构,如数组、队列、链表和栈;非线性结构包括图结构、树结构、二维数组、广义表和多维数组。
|
5月前
|
存储 算法 测试技术
【初阶数据结构篇】实现顺序结构二叉树(堆的实现方法)
注意传过去的参数是插入的位置,即插入前的size,在调整完后再将size++
36 0