常用数据结构有哪些

网上有关“常用数据结构有哪些”话题很是火热,小编也是针对常用数据结构有哪些寻找了一些与之相关的一些信息进行分析,如果能碰巧解决你现在面临的问题,希望能够帮助到您。

数据结构分为8类有:数组、栈、队列、链表、树、散列表、堆、图。数据结构是指相互之间存在着一种或多种关系的数据元素的集合和该集合中数据元素之间的关系组成 。?

1、数组

数组是可以再内存中连续存储多个元素的结构,在内存中的分配也是连续的,数组中的元素通过数组下标进行访问,数组下标从0开始。例如下面这段代码就是将数组的第一个元素赋值为 1。

2、栈

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

3、队列

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

4、链表

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

5、树

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

6、散列表

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

7、堆

堆是一种比较特殊的数据结构,可以被看做一棵树的数组对象,具有以下的性质:堆中某个节点的值总是不大于或不小于其父节点的值;堆总是一棵完全二叉树。将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆。常见的堆有二叉堆、斐波那契堆等。

8、图

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

百度百科—数据结构

一、栈:乒乓球盒子,先进后出

使用场景:在编译器的语法检查中,一个过程就是检查各种括号是否匹配,比如 ([]) ,这就是匹配的,而 {[}] 就不匹配了。可以用栈来实现括号匹配。

二、队列:排队取餐,先进先出

使用场景:当多个任务分配给打印机时,为了防止冲突,创建一个队列,把任务入队,按先入先出的原则处理任务。

三、堆:是用数组来存储的 完全二叉树 的结构(完全二叉树就是除了最底层,其它层都必须填满,最后一层可以从左到右填满)

堆分为两种:最大堆和最小堆,两者的差别在于节点的排序方式。

在最大堆中,父节点的值比每一个子节点的值都要大。在最小堆中,父节点的值比每一个子节点的值都要小。这就是所谓的“堆属性”,并且这个属性对堆中的每一个节点都成立。

使用场景:给定一个数组,其中的元素都是无序杂乱的,我们怎么对它进行堆排序呢?

四、链表:单向链表和双向链表,每一个节点都由数据+指针组成。链表的头结点不存储数据,但头节点指针指向第一个真正有数据的节点

链表优点:

插入删除速度快

内存利用率高,不会浪费内存

大小没有固定,拓展很灵活。

链表缺点:

不能随机查找,必须从第一个开始遍历,查找效率低

数组的优点:

随机访问性强,查找速度快

数组的缺点:

插入和删除效率低

可能浪费内存

内存空间要求高,必须有足够的连续内存空间。

数组大小固定,不能动态拓展

关于“常用数据结构有哪些”这个话题的介绍,今天小编就给大家分享完了,如果对你有所帮助请保持对本站的关注!

本文来自作者[寄山少爷]投稿,不代表拾光号立场,如若转载,请注明出处:https://7k54.com/shiga/13048.html

(11)
寄山少爷的头像寄山少爷签约作者

文章推荐

发表回复

作者才能评论

评论列表(3条)

  • 寄山少爷的头像
    寄山少爷 2025年09月27日

    我是拾光号的签约作者“寄山少爷”

  • 寄山少爷
    寄山少爷 2025年09月27日

    本文概览:网上有关“常用数据结构有哪些”话题很是火热,小编也是针对常用数据结构有哪些寻找了一些与之相关的一些信息进行分析,如果能碰巧解决你现在面临的问题,希望能够帮助到您。数据结构分为8...

  • 寄山少爷
    用户092706 2025年09月27日

    文章不错《常用数据结构有哪些》内容很有帮助