0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

十种典型的数据结构及其特性

nlfO_thejiangme 来源:未知 作者:李倩 2018-03-19 15:54 次阅读

数据结构是软件开发的关键部分,也是开发人员面试经常遇到的问题,它们通常以专用的格式进行数据组织和存储。本文我们将会介绍十种典型的数据结构及其特性。需要注意的是,虽然一些数据结构包含了时间复杂度O,但不完全都有因为时间复杂度很多时候与你的代码书写有关。实际使用时,大多数的数学结构都不需要你自己实现它们,除非像C语言这样的底层语言。虽然大多数高级语言一般都会内置这些数据结构,但如果你知道如何实现这些数据结构将会为你在开发工作中带来巨大优势,说不定当你尝试编写高性能代码时就会派上用场。

1. 链表

链表属于最基本的数据结构。由于许多数据结构既可以用数组也可以用链表来实现,所以通常会与数组进行比较,但它们各有优缺点。

链表通常由一组代表一个序列的节点组成。 每个节点包含存储的任意类型实际数据以及指向序列中下一个节点的指针。特殊的,还有双向链表,其中每个节点都有两个指针,分别起到承前启后的作用。

链表中最基本的操作是插入链表、删除链表以及查询链表。下表为链表的时间复杂度:

2. 堆栈

堆栈属于一种基本的数据结构,你只能在堆栈的顶部插入或删除项目。这有点像一堆书, 如果你想看堆栈中间的一本书,你必须先将它上面上面的所有书移走。

堆栈遵循后进先出,也就是说你最后放入堆栈的项目是第一个出栈的项目。

对堆栈主要有三种操作:push,即插入新内容到堆栈;pop,从堆栈中删除一项内容;pip,显示堆栈的内容。

堆栈时间复杂度:

3.队列

你可以把队列想象成一家杂货店里排队买单的人,队伍中第一个人先被服务。

队列遵循先进先出,也就是说一旦你想添加了新元素,你要想删除它,必须先删除它前面的的所有元素。队列只有两个主要操作:入队和出队。 入队,就是将新的内容插入队列后面,而出队就是前面所有的内容。

队列时间复杂度:

4.集合

以集合形式存储的数据结构中不存在任何特定的顺序,也不存在重复的值。除了向集合中添加新元素或者删除元素之外,还有一些重要的集合函数可以进行两组集合的处理。

并集,将来自两个不同集合的所有元素结合起来作为新集合返回(不重复).

交集,给定两个集合,此函数返回另一个集合,包含属于两个集合的共同部分。

差集,给定两个集合,此函数返回另一个集合,其中各个元素属于一个集合,但不属于另一个集合。

子集 ,返回一个布尔值,显示一个集合中的所有元素是否包含在不同的集合中。

5. MAP

Map是容器的一种,也属于一种数据结构,它将数据存储在键/值对中,且每个键是唯一的。 map有时也称为关联数组或字典,通常被用于快速查找数据。 Map可以进行以下操作:

在集合中增加一对

从集合中删除一对

修改现有的一对

查找与特定键相关联的值

6.哈希表

哈希表是包含键/值对的地图数据结构,使用散列函数来把关键码值映射到表中一个位置来访问记录,以加快查找的速度。散列函数通常将一个字符串作为输入,并输出一个数值。散列函数对相同的输入提供相同的输出编号。 当两个输入哈希得到相同的数字输出时,称为碰撞。

我们的目标是没有碰撞。所以当你将一个键/值对输入到一个散列表中时,这个键将通过散列函数映射到一个数字,用作值存储的实际键。 当你尝试再次访问相同的密钥时,哈希函数将处理该密钥并返回相同的数字结果,用于查找关联的值。 算法速度非常快,查找的时间复杂度仅为O(1)。

Hash table 时间复杂度:

7.二叉搜索树

树是由节点组成的数据结构,它具有以下特征:

每棵树都有一个根节点(位于顶部)。

根节点具有零个或多个子节点。

每个子节点都有零个或多个子节点。

二叉搜索树还具有额外的两个特征:

每个节点最多有两个子节点.

对于每个节点,它左边的子节点小于当前节点,而右边的子节点则大于当前节点。

每个节点最多有两个子节点。

二叉搜索树允许快速查找、添加和删除内容。 从它的设计结构来看,每次比较后都会跳过树的大约一半内容,因此每次查找、插入或删除需要的操作时间与存储在树中的内容数量的对数成比例。

二叉树时间复杂度:

8. 前缀树或字典树

前缀树或字典树,是一种搜索树。 前缀树中存储数据的每个步骤其实就是操作一个节点,它通常被用来存储单词,可以进行快速查找,例如单词自动构成功能。

语言字典树中的每个节点都包含一个单词的一个字母。 你可以按照树状结构的一条分支拼写出一个单词。 当字母的顺序与字典中的其他单词不同或者一个单词完成时,开始分支。每个节点都包含一个字母(数据)和一个布尔值(用于指示该节点是否是单词中的最后一个节点)。

看看上面的图像,你可以构成很多单词。从顶部的根节点开始并往下,这个字典树包含了ball, bat, doll, do, dork, dorm, send, sense这些单词。

9.二叉堆

二叉堆是特殊的树数据结构。形式上看,它从顶点开始,每个节点有两个子节点,每个子节点又各自有自己的两个子节点;数值上看,每个节点的两个子节点都比它大或小。

二叉堆有两种:最大堆和最小堆。最大堆:父结点的键值总是大于或等于任何一个子节点的键值;最小堆:父结点的键值总是小于或等于任何一个子节点的键值。

在二叉堆上可以进行插入节点、删除节点、取出值最小的节点、减小节点的值等基本操作。不同层之间的顺序很重要,但同一层上节点的顺序无关紧要。 如图所示,你可以看到最小堆的第三层的值是10,6和12,这些数字并不是按照顺序排列的。

二叉堆时间复杂度:

10. 图

图是由节点(也称为顶点)与它们之间的连接(称为边)构成的集合。图也被称为网络

社交网络是典型的图的例子,节点是人,边代表他们互相认识的关系。

主要有两种类型的图:有向和无向。无向图是指在节点之间的边上没有任何方向的图。相反,有向图表示每条边上都有方向的图。

表示图的两种常用方式是邻接表和邻接矩阵:

邻接列表,表示一个列表的左侧是节点,右侧列出了它所连接的所有其他节点。

邻接矩阵,则是一个数字网格。其中每个行或列表示图中的不同节点。每一行和一列的交点是一个表示关系的数字。0表示没有边或没有关系,1表示有一种关系,而大于1的数字则可表示不同的权重。

通过遍历算法可以遍历或访问图中的节点。遍历算法的主要类型有广度优先搜索和深度优先搜索,可以被用于确定节点与根节点的接近程度。观看下面的视频你可以学习到如何在JavaScript中实现广度优先搜索。

邻接列表的时间复杂度:

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据结构
    +关注

    关注

    3

    文章

    573

    浏览量

    40092
  • 链表
    +关注

    关注

    0

    文章

    80

    浏览量

    10547

原文标题:盘点 | 如何组织你的数据?这里有十种常见的数据结构解读

文章出处:【微信号:thejiangmen,微信公众号:将门创投】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    快速介绍8常用数据结构

    数据结构是一特殊的组织和存储数据的方式,可以使我们可以更高效地对存储的数据执行操作。数据结构在计算机科学和软件工程领域具有广泛而多样的用途
    发表于 06-21 09:27 732次阅读
    快速介绍8<b class='flag-5'>种</b>常用<b class='flag-5'>数据结构</b>

    什么是数据结构(Data Structrue)

    的一个一个元素数据对象:具有相同特性数据元素的集合结构数据元素之间具有的关系(联系) 二. 
    发表于 02-09 17:17

    数据结构

    1.数据结构的概念 所谓数据结构是指由某一数据对象及该对象中所有数据成员之间的关系组成的集合。成员之间的关系有很多种,最常见的是前后件关系。 2.
    发表于 03-04 14:13

    请问怎么做一个跑马灯有十种模式,第十种模式有三音乐,可加速减速和无线遥控?

    我现在想做一个跑马灯,这个跑马灯有十种模式,第十种模式要求有三音乐。,还得有数码管显示第几种模式。可以无线遥控。求哪位大神可以帮我。小女子必有重谢。
    发表于 07-19 04:49

    常见的数据结构

    胡乱的,这就要求我们选择一好的方式来存储数据,而这也是数据结构的核心内容。数据存储一直以来大家面对的数据存储,都是类似存储 1、 2、{a
    发表于 05-10 07:58

    数据结构教程,下载

    1. 数据结构的基本概念 2. 算法与数据结构3. C语言的数据类型及其算法描述要点4. 学习算法与数据结构的意义与方法
    发表于 05-14 17:22 0次下载
    <b class='flag-5'>数据结构</b>教程,下载

    GPIB命令的数据结构

    针对GPIB命令的结构,提出一存储GPIB命令的数据结构。根据GPIB命令的层次关系的特点,选择数据结构中“树”的概念来存储GPIB命令结点;并考虑程序实现的效率问题以及管理维护
    发表于 02-10 16:20 70次下载

    GPIB命令的数据结构

    针对GPIB命令的结构,提出一存储GPIB命令的数据结构。根据GPIB命令的层次关系的特点,选择数据结构中“树”的概念来存储GPIB命令结点;并考虑程序实现的效率问题以及管理维护
    发表于 01-04 10:13 0次下载

    数据结构与算法

    全国C语言考试公共基础知识点——数据结构与算法,该资料包含了有关数据结构与算法的全部知识点。
    发表于 03-30 14:27 0次下载

    十种典型测控电路图全解

    十种典型的测控电路图全解,包括数控机床的速度、位移测控系统、温度测量与控制系统、数控机床的速度、位移测控系统等,非常全面,希望对大家有用。
    发表于 10-10 11:37 1.2w次阅读
    几<b class='flag-5'>十种</b><b class='flag-5'>典型</b>测控电路图全解

    十种方法能保护云数据安全

    十种方法能保护云数据安全
    发表于 01-14 12:00 12次下载

    数据结构是什么_数据结构有什么用

    数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一或多种特定关系的数据元素的集合。通常情况下,精心选择的
    发表于 11-17 14:45 1.6w次阅读
    <b class='flag-5'>数据结构</b>是什么_<b class='flag-5'>数据结构</b>有什么用

    什么是数据结构?为什么要学习数据结构数据结构的应用实例分析

    本文档的主要内容详细介绍的是什么是数据结构?为什么要学习数据结构数据结构的应用实例分析包括了:数据结构在串口通信当中的应用,数据结构在按键
    发表于 09-26 15:45 14次下载
    什么是<b class='flag-5'>数据结构</b>?为什么要学习<b class='flag-5'>数据结构</b>?<b class='flag-5'>数据结构</b>的应用实例分析

    十种pandas数据编码的方法分享

    题主表示pandas用起来很乱,事实真的如此吗?本文就将先如何利用pandas来行数据转换/编码的十种方案,最后再回答这个问题。
    的头像 发表于 05-10 15:33 1258次阅读

    NetApp的数据结构是如何演变的

    混合和多云部署模型是企业IT组织的新常态。随着这些复杂的环境,围绕数据管理的新挑战出现了。NetApp的数据管理愿景是一无缝连接不同的数据结构云,无论它们是私有环境、公共环境还是混合
    发表于 08-25 17:15 0次下载
    NetApp的<b class='flag-5'>数据结构</b>是如何演变的