数据结构分类

数据结构分类

数据结构是指相互之间存在着一种或多种关系的数据元素的集合和该元素中数据元素之间的关系组成,常用的数据结构有:数组,栈,链表,队列,树,图,堆,散列表等

1.数组

数组是可以在内存中连续存储多个数据元素的结构,在内存中的分配也是连续的,数组的元素通过数组下标进行访问,数组下标从0开始,

int[] data = new int[100];

data[0] = 1;

该段代码就是将数组的第一个元素赋值为1;

优点:按照索引查询元素速度快,按照索引遍历数组方便

缺点:数组的大小固定后就无法扩容了,数组只能存储一种类型的数据,添加,删除的操作慢,因为要移动其他的元素

适用场景:频繁查询,对存储空间要求不大,很少增加和删除的情况

2.栈

栈是一种特殊的线性表,仅能在线性表的一端进行操作,栈顶允许操作,栈底不允许操作。栈的特点是:先进后出,或者说是后进先出,从栈顶放入元素的操作叫入栈,取出元素叫出栈。

栈的结构就像一个集装箱,越先进去的越晚才拿出来,所以,栈常用于实现递归功能方面的场景,例如斐波那契数列

3.队列

队列与栈一样,也是一种线性表,不同的是,队列可以在一端添加元素,在另一端取出元素,也就是:先进先出。从一端放入元素的操作称为入队,取出元素为出队

使用场景:因为队列先进先出的特点,在多线程阻塞队列管理中非常适用

4.链表

链表是物理存储单元上非连续的、非顺序的存储结构,数据元素的逻辑顺序是通过链表的指针地址实现,每个元素包含两个点,一个是存储元素的数据域(内存空间),另一个是指向下一个结点地址的指针域,根据指针的指向,链表能形成不同的结构,例如单链表,双向链表,循环链表等。

优点:链表是很常用的一种数据结构,不需要初始化容量,可以任意加减元素;添加或删除元素时只需要改变前后两个元素结点的指针地域即可,所以添加快,删除也很快;

缺点:因为含有大量的指针域,占用空间较大;查找元素需要遍历链表来查找,非常耗时。

适用场景:数据量小,需要频繁增加,删除操作的场景

5.树

树是一种数据结构,它是由n(n>=1)个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像是一个倒挂的树,也就是说它的跟朝上,叶朝下,它有以下的特点:

每个结点有零个或多个子节点;

没有父节点的节点称为根节点;

每一个非根节点有且只有一个父节点;

除了根节点外,每个子节点可以分为多个不相交的子树;

主要使用的树为最为特殊的二叉树,二叉树既有链表的好处,也有数组的好处,是两者的优化方案,在处理大批量的动态数据方面非常有用。

6.散列表(哈希表)

散列表,也叫哈希表,是根据关键码和值(key和value)直接进行访问的数据结构,通过key和value来映射到集合中的一个位置,这样就可以很快找到集合中对应的元素

记录的存储位置=f(key)

这里的对应关系 f 成为散列函数,又称为哈希 (hash函数),而散列表就是把Key通过一个固定的算法函数既所谓的哈希函数转换成一个整型数字,然后就将该数字对数组长度进行取余,取余结果就当作数组的下标,将value存储在以该数字为下标的数组空间里,这种存储空间可以充分利用数组的查找优势来查找元素,所以查找的速度很快。

哈希表在应用中也是比较常见的,就如Java中有些集合类就是借鉴了哈希原理构造的,例如HashMap,HashTable等,利用hash表的优势,对于集合的查找元素时非常方便的,然而,因为哈希表是基于数组衍生的数据结构,在添加删除元素方面是比较慢的,所以很多时候需要用到一种数组链表来做,也就是拉链法。拉链法是数组结合链表的一种结构,较早前的hashMap底层的存储就是采用这种结构,直到jdk1.8之后才换成了数组加红黑树的结构.

7.堆

堆是一种比较特殊的数据结构,可以被看做一棵树的数组对象,具有以下的性质:

堆中某个节点的值总是不大于或不小于其父节点的值;

堆总是一棵完全二叉树。

将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆。常见的堆有二叉堆、斐波那契堆等。

堆的定义如下:n个元素的序列{k1,k2,ki,…,kn}当且仅当满足下关系时,称之为堆。
(ki <= k2i,ki <= k2i+1)或者(ki >= k2i,ki >= k2i+1), (i = 1,2,3,4…n/2),满足前者的表达式的成为小顶堆,满足后者表达式的为大顶堆,这两者的结构图可以用完全二叉树排列出来,

8.图

图是由结点的有穷集合V和边的集合E组成。其中,为了与树形结构加以区别,在图结构中常常将结点称为顶点,边是顶点的有序偶对,若两个顶点之间存在一条边,就表示这两个顶点具有相邻关系。图:图是由结点的有穷集合V和边对的集合E组成,为了将图与树形结构进行区分,在图结构中常常将结点称为顶点,边是顶点的有序偶对。若两个顶点之间存在一条边,则表示这两个顶点具有相邻关系。

有向图和无向图:根据用来链接两个顶点之间的边是否有方向(箭头指向)分为有向图和无向图。弧:在有向图中,通常将边称为弧,含箭头的一端称为弧端,另一端则称为弧尾,记作,表示从顶点vi到vj有一条边。

顶点的度、出度、入度:在无向图中,边记为(vi,vj),该式等价于有向图中的,两条边。与顶点v相关的边的条数称为顶点v的度。在有向图中指向顶点v的边的条数称为顶点v的入度,由顶点v发出的边的条数称为顶点v的出度。

有向完全图和无向完全图:若有向图中有n个顶点,则最多有n(n-1)条边(图中任意两个顶点都有两条边相连,且顶点A-B与顶点B-A是两条边),将具有n(n-1)条边的有向图称为有向完全图。若无向图中有n个顶点,则最多有n(n-1)/2条边(任意两个顶点之间都有一条边,且顶点A-B与顶点B-A是同一条边),将具有n(n-1)/2条边的无向图称为无向完全图。

路径和长度:在一个图中,路径为相邻顶点序偶所构成的序列。路径长度是指路径上边的数目。

简单路径:序列中顶点不重复出现的路径称为简单路径。

回路:若一条路径的第一个顶点和最后一个顶点相同,则这条路径是一条回路。

权和网:图中每条边都可以附带一个对应的数,这种与边相关的数称为权,权可以表示从一个顶点到另一个顶点的距离或者花费的代价。边上带有权的图称为带权图,也称为网。

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSDN是一个以技术为主题的社区平台,其中涵盖了各种编程和计算机科学相关的内容。在数据结构这一领域中,CSDN对其进行了细分和分类,以方便用户查找和学习相关知识。 CSDN将数据结构分为几个主要分类: 1. 线性结构:这一分类主要包括各种线性数据结构,例如数组、链表、栈和队列等。线性结构的特点是数据元素之间存在一对一的关系,可以按照特定的顺序存储和访问。 2. 树结构:包括二叉树、平衡树、二叉搜索树等。树结构具有层次分明的特点,可以用于表示层级关系和递归结构。其中二叉搜索树是常用的数据结构之一,能够快速地进行查找、插入和删除操作。 3. 图结构:图是由节点和边组成的集合,用于表示各种复杂的关系和网络结构。在图结构分类中,常见的包括有向图、无向图、带权图等。图结构的应用广泛,例如社交网络、路由算法等领域。 4. 散列结构:散列结构是通过散列函数将数据元素映射到存储位置的一种数据结构。散列结构可以实现快速的查找和插入,常见的应用有哈希表、集合和字典等。 此外,CSDN还对数据结构进行了更细致的分类,如查找算法、排序算法等。这些分类有助于用户深入了解和学习数据结构,掌握各种数据结构的基本原理和应用场景。 总之,CSDN通过分类整理和归纳,为用户提供了一个方便、系统的学习数据结构的平台,使用户能够有针对性地查找和学习相关知识。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值