当前位置:首页 > 科技  > 软件

数据结构与集合的不解之缘,你了解多少?

来源: 责编: 时间:2023-11-07 17:16:32 385观看
导读本篇文章将简要介绍数据结构,让读者了解它们在计算机中以何种结构方式存在。那么,什么是数据结构呢?下面我们来详细解释。数据结构1.1 数据结构有什么用?数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在

本篇文章将简要介绍数据结构,让读者了解它们在计算机中以何种结构方式存在。那么,什么是数据结构呢?下面我们来详细解释。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

数据结构

1.1 数据结构有什么用?

数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。通常情况下,精心选择的数据结构可以带来更高的运行或者存储效率。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com


oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

数据结构往往同高效的检索算法和索引技术有关。这句话是啥意思呢?oB328资讯网——每日最新资讯28at.com

我们举个简单的例子。就像金庸小说中所写的,武功招式就相当于我们的算法,而数据结构就是我们的内功心法;而武功的高低,不仅仅是武功招式,更重要的是 学会的内功心法。就比如张无忌在学会九阳神功之后,就可以大战六大门派。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

而数据结构的学习,也会让我们事半功倍。凭借着“数据结构+算法=程序”这句话,Pascal之父获得了图灵奖。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

总结来说:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

数据结构就是一种是将世界上各种数据转化为计算机可以存储和操作的形式,定义了逻辑结构如何在计算机上存储,以及相关的基本操作。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

算法是程序猿通过调用不同数据结构的基本操作,从而实现了数据的处理。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

而这两点使我们作为程序开发人员的必备基本功,不是一朝一夕就能成为绝世高手的,我们需要一步步去不断的学习积累,积硅步以致千里。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

1.2 常见的数据结构

在计算机学科中,数据结构是一门很重要的基础学科,知识点很多。在这里我们不讲那么多,只讲述我们集合中用到的几种数据结构,同学们可以下去自行学习更多的数据结构的知识。常用结构三个:数组、链表、红黑树。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

我们分别来了解一下:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

1)数组

数组的定义:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

  • 数组是相同类型数据的有序集合;
  • 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成;
  • 其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们。

oB328资讯网——每日最新资讯28at.com

存储思路:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

所有数据存储在连续的空间中,数组中的每个元素都是一个具体的数据。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

数组的特点:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

  • 使用连续分配的内存空间;
  • 一次申请一大段连续的空间,需要事先声明最大可能要占的固定内存空间。

oB328资讯网——每日最新资讯28at.com

如下图:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com


oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

  • 通过索引,查询快
  • 当给数组插入新元素时,数组中的a2,a3,a4整体后移,代价高。
  • 如果插入元素时,数组长度,还要重新创建一个数组,然后循环赋值,代价高

oB328资讯网——每日最新资讯28at.com

优点:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

设计简单,读取与修改表中的任意一个元素的时间都是固定的,速度快 。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

缺点:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

容易造成内存浪费;删除或者插入数据需要移动大量数据,速度慢。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

2)链表

每个数据单独存在一小块内存中,这个单元叫做节点,每个节点知道下一个节点的地址,叫做单向链表。每个节点既知道下一个节点地址,又知道上一个节点地址,叫做双向链表。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

链表的特点:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

  • 使用不连续的内存空间;
  • 不需要提前声明好指定大小的内存空间,一次申请一小块,按需申请。

oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

查询元素,需要通过节点一次向后查找,直到查找到指定元素oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

增删元素:只需修改连接节点的地址即可。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

优点: 充分节省内存空间,数据插入和删除方便,不需要移动大量数据。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

缺点: 查询数据必须按顺序找到该数据,操作麻烦。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

3)红黑树

简单理解,就是一种类似于我们生活中树的结构,只不过每个节点最多只有两个叶子。计算机世界的树,刚好与我们现实中的树成镜像相反,树根在上,树枝在下。二叉树如下图:oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

而我们要说的是二叉树的一种比较有意思的叫做红黑树,红黑树本身就是一颗二叉查找树。我们在这里只需要记住它的特点就可以非常方便的对树中的所有节点进行排序和检索。oB328资讯网——每日最新资讯28at.com

oB328资讯网——每日最新资讯28at.com

小结

本文介绍了三种常用的数据结构:数组、链表和红黑树,以及这些数据结构在计算机中的重要意义。通过学习这些内容,我们可以逐步深入了解计算机世界。oB328资讯网——每日最新资讯28at.com


oB328资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-17547-0.html数据结构与集合的不解之缘,你了解多少?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 使用Python从零实现多分类SVM

下一篇: 基于Topic的消息发布与消费模式

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • K60 Pro官方停产 第三方瞬间涨价

    虽然没有官方宣布,但Redmi的一些高管也已经透露了,Redmi K60 Pro已经停产且不会补货,这一切都是为了即将到来的K60 Ultra铺路,属于厂家的正常操作。但有意思的是该机在停产之后
  • JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • Rust中的高吞吐量流处理

    作者 | Noz编译 | 王瑞平本篇文章主要介绍了Rust中流处理的概念、方法和优化。作者不仅介绍了流处理的基本概念以及Rust中常用的流处理库,还使用这些库实现了一个流处理程序
  • Automa-通过连接块来自动化你的浏览器

    1、前言通过浏览器插件可实现自动化脚本的录制与编写,具有代表性的工具就是:Selenium IDE、Katalon Recorder,对于简单的业务来说可快速实现自动化的上手工作。Selenium IDEKat
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • 微软邀请 Microsoft 365 商业用户,测试视频编辑器 Clipchamp

    8 月 1 日消息,微软近日宣布即将面向 Microsoft 365 商业用户,开放 Clipchamp 应用,邀请用户通过该应用来编辑视频。微软于 2021 年收购 Clipchamp,随后开始逐步整合到 Microsof
  • 小米公益基金会捐赠2500万元驰援北京、河北暴雨救灾

    8月2日消息,今日小米科技创始人雷军在其微博上发布消息称,小米公益基金会宣布捐赠2500万元驰援北京、河北暴雨救灾。携手抗灾,京冀安康!以下为公告原文
  • 利用职权私自解除被封帐号 Meta开除20多名员工

    11月18日消息,据外媒援引知情人士表示,过去一年时间内,Facebook母公司Meta解雇或处罚了20多名员工以及合同工,指控这些人通过内部系统以不当方式重置用户帐号,其
Top