数据结构——介绍

什么是数据结构

在《数据结构,算法及应用》一书中有这样的解释“数据结构是数据对象,存在与该对象的实例以及组成实例的数据元素之间的各种关系,并且这种关系可以通过定义相关的函数来给出。”他将数据对象定义为一个实例或值的集合。
上面这种说发比较难以理解,我们可以简单的理解为数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。通常情况下,精心选择的数据结构可以带来更高的运行或者存储效率。数据结构往往同高效的检索算法和索引技术有关。(百度百科https://baike.baidu.com/item/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84/1450?fr=aladdin
数据结构包含三方面的内容:数据的逻辑结构,数据的存储结构,数据的运算。

  • 数据的逻辑结构即数据元素之间的逻辑关系,是一种独立于计算机的抽象概念。例如一组元素中按顺序排列的这种前后关系。
  • 数据的存储结构即数据元素以及其逻辑关系在计算机存储器中的表现形式。是一种具体的概念,真实的存储表现。例如数据结构中的每个数据元素都按照顺序依此存储在一片连续的存储单元中。
  • 数据的运算即能够对数据施加的操作。例如增删改查和排序。

数据结构的这三个方面是一个有机的整体,缺一不可。数据的逻辑结构,存储结构及运算任何一个发生变化都将导致一个全新的数据结构出现。

数据结构的的逻辑关系

数据结构的结点之间的逻辑关系可以分为以下两类:

1. 线性结构

简单的理解,线性结构就是各个结点具有线性关系(一个有序数据元素的集合)。线性结构应该包括如下内容:

  • 线性结构是非空集
  • 线性结构有且仅有一个开始结点和结束结点
  • 线性结构中每个结点最多可以有一个直接前驱结点,同时最多可以有一个直接后驱结点。
    典型的线性结构有:栈,队列
2. 非线性结构

非线性结构就是各个结点之间具有多个对应关系。非线性结构应该包括如下内容:

  • 非线性结构是非空集
  • 非线性结构的一个结点可能有多个直接前驱结点和直接后驱结点。
    典型的非线性结构有:广义表,树结构,图结构

数据结构的存储方式

数据的存储结构是数据结构的一个重要内容,在计算机中,数据的存储结构采用如下四种方法来实现:

1.顺序存储方式

顺序存储方式就是在一块连续的存储区域一个接着一个的存放数据。顺序存储方式把逻辑上相邻的两个结点存储在物理地址相邻的存储单元里,结点间的逻辑关系由存储单元的邻接关系来提现。该存储方式主要用于线性逻辑结构的数据存放,而对于图和树等非线性逻辑结构则不适用。

2.链式存储方式

链式存储方式比较灵活,它不要求逻辑上相邻的结点在物理存储上的位置相邻。结点间的逻辑关系通过结点附带的引用字段来表示。一个结点的引用字段往往指向下一个结点的存储位置。

3.索引存储方式

索引存储方式是采用附加的索引表的方式来存储结点信息。索引表由若干索引项组成,索引项的的一般形式为(关键字和数据元素存储地址)。其中关键字是能够唯一标识一个结点的数据项。就像新华字典一样。
按照索引表中索引项所对应的结点的数量,索引存储方式还可以细分为稠密索引和稀疏索引

  • 稠密索引(Dense Index):每个结点在索引表中对应一个索引项,其中索引项中的地址指向结点的存储位置
  • 稀疏索引(Spare Index):索引表中的一个索引项对应一组结点,索引项中的地址指向这一组结点的起始存储位置。
4.散列存储方式

散列存储方式是根据结点的关键字直接计算出该结点的存储地址的一种存储方式。

常用的数据结构

1.数组(Array)

数组是一种聚合数据类型,是将具有相同数据类型的若干元素有序组织在一起的集合。数组可以说是最基本的数据结构。一个数组可以分解成多个数组元素,按照数据元素的类型的不同,数组类型可以分为整型数组,字符型数组,浮点型数组,对象型数组。数组还可以分为一维数组,二维数组和多为数组等形式。

2.栈(Stack)

栈是一种特殊的线性表,其只能在表的一个固定端进行数据结点的插入和删除操作。栈按照先进后出的原则来存储数据,也就是说先入栈的被压入了栈底,最后入栈的则在栈顶,读出数据时从栈顶开始逐个读出。栈中没有数据时称为空栈。

3.队列(Queue)

队列和栈类似,也是一种特殊的线性表。和栈不同的是 队列只允许在表的一端进行插入操作,而在另一端进行删除操作。一般来说进行插入操作的是队尾,进行删除操作的是队首,也就是说队列是按照先进先出的原则进行数据存储。队列中没有数据的时候称为空队列。

4.链表(LinkedList)

链表是一种按照链式存储结构存储数据元素的数据结构,这种存储结构在物理上具有非连续的存储区域的特点。链表由一系列的数据结点构成,每个数据结点包括数据域和引用域两部分,其中引用域存储了逻辑关系上下一个结点的存储地址。链表中数据元素的逻辑关系是通过链表中的引用链次序来实现的。

5.树(Tree)

树是典型的非线性结构,是包含n个数据结点的有穷集合。在树结构中有且仅有一个跟结点,跟结点没有前驱结点但有0个或多个后继结点,在树结构中其他结点有且仅有一个前驱结点,但有0个或多个后继节点。

6.图(Graph)

图是另外一种典型的非线性结构,在图结构中数据结点一般称为顶点,而边是顶点的有序偶对,如果两个顶点之间存在一条边,那么就表示这两个顶点具有相邻关系。

7.堆(Heap)

堆是一种特殊的树结构,一般讨论的堆都是二叉堆。堆的特点是跟结点的值是所有结点中最小的或者最大的,并且根节点的两个子树也是一个堆结构。

8.散列表(Hash)

散列表一般指哈希表,是根据关键码值直接进行访问的数据结构。也就是说它通过关键码值映射到表中一个位置来访问记录,以加快查找的速度。这个映射函数叫做散列函数,存放记录的数组叫做散列表。

本内容均来自《Java常用算法手册》

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容