数据结构有8类:
1、数组: 数组是可以在内存中连续存储多个元素的结构,内存中分配也是连续的。通过下标访问,下标从0开始。
2、栈:栈是一种特殊的线性表,仅能在线性表的一端操作,栈顶允许操作,栈底不允许操作。 先进后出(后进先出), 放入元素叫入栈,取出元素叫出栈。
3、队列:队列也是一种线性表,队列可以在一端添加元素,在另一端取出元素。先进先出。 放入元素叫入队,取出元素叫出队。
4、链表:链表是物理存储单元上非连续的,非顺序的存储结构,数据元素的逻辑顺序是通过链表的指针地址实现,每个元素包含两个节点,一个是存储元素的数据域(内存空间),另一个是指向下一个节点地址的指针域。 根据指针的指向,链表能够形成不同的结构,例如: 单链表、双向链表、循环链表等
5、树:树是由n(n>=1) 个悠闲节点组成一个具有层次关系的集合。 根据不同的特征,又分为: 红黑树、二叉树等
6、散列表(哈希表):散列表是根据关键码和值(key 和 value) 直接进行访问的数据结构,通过key和value来映射到集合中的一个位置,这样就可以很快找到集合中的对应元素
7、堆:堆是一种比较特殊的数据结构,可以被看做一棵树的数组对象,具有以下的性质:堆中某个节点的值总是不大于或不小于其父节点的值;堆总是一棵完全二叉树。将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆。常见的堆有二叉堆、斐波那契堆等。
8、图:图是由结点的有穷集合V和边的集合E组成。其中,为了与树形结构加以区别,在图结构中常常将结点称为顶点,边是顶点的有序偶对,若两个顶点之间存在一条边,就表示这两个顶点具有相邻关系。
又可以分为: 线性结构 和 非线性结构
线性结构:特点是数据元素之间存在一对一的线性关系。 线性结构有两种不同的存储结构: 顺序存储结构(数组) 和 链式存储结构(链表)。
主要有 数组、队列、链表和栈。
非线性结构:主要有: 二维数组、多维数组、广义表、树结构、图结构
数据结构的细分类:
<