数据结构引论

数据结构(js)

数组

数组在js中具有非常重要的地位,js的底层对数据进行了深度的封装,提供了很多方法。

数组创建

  1. 字面量 let arr = [1,2,3,4,5];
  2. 通过 new 关键字 const arr = new Array(7)
    const arr = (new Array(7)).fill(1) 可以用 fill 方法填充数据,但是这个方法不能填充引用类型的值,它实际上传入的是入参的引用,当你传入引用类型时,因此 二维数组常用 for循环创建,for循环也是效率最高的方法。

数组访问常用循环几维的数组常常就需要几次嵌套的循环,因此,我们一般使用 for 循环创建数组。

底层提供的数组增删方法

增加元素
  1. push() 方法向数组的末尾添加一个或多个元素,并返回新的长度。
  2. unshift() 方法向数组的开头添加一个或更多元素,并返回新的长度。
  3. splice() 方法向数组的指定位置添加元素,并返回被删除的元素。
    splice 方法有三个入参:1. 起始索引 2. 删除的元素个数 3. 新的元素
    arr.splice(1, 0, 3); 代表的是从索引1开始,删除0个元素,添加新元素3到1索引位置后
删除数组元素
  1. pop() 方法从数组的末尾删除一个元素,并返回该元素。
  2. shift() 方法从数组的开头删除一个元素,并返回该元素。
  3. splice() 方法从数组的指定位置删除元素。同上。

栈和队列 (Stack and Queue)

栈和队列是两种常见的数据结构,它们都用于存储数据,但它们在存储和取出数据上有所不同。zai栈是一种后进先出(LIFO)的数据结构,即后添加的元素先取出。 队列是一种先进先出(FIFO)的数据结构,即先添加的元素先取出。

在js中,我们可以使用数组来实现栈和队列。

对于栈来说,我们可以使用push()方法添加元素,使用pop()方法取出元素。也就是说只用这两个方法操作的数组,就可以实现栈的功能。

队列则使用push()方法添加元素,使用shift()方法取出元素。也就是说只用这两个方法操作的数组,就可以实现队列的功能。

链表 (Linked List)

链表是一种常见的数据结构,它由节点(Node)组成,每个节点包含数据元素和指向下一个节点的指针。链表是一种动态数据结构,它可以在任意位置添加或删除节点,而不需要重新分配内存。

链表和数组的区别在于,链表在内存中存储的元素是动态的,而数组在内存中存储的元素是静态的。

特性:链表的插入/删除效率较高,而访问效率较低;数组的访问效率较高,而插入效率较低。

树在计算机中是对现实中树的抽象,将树根抽象成根节点,叶子抽象成叶子节点,中间节点抽象成内部节点。
树根节点是唯一的,每个节点最多只能有一个父节点,每个节点最多只能有一个子节点。

关于树最重要的是二叉树的掌握:

二叉树是树结构中的一种,它的特点是每个节点最多有两个子节点。

数据域

左侧子结点(左子树根结点)的引用

右侧子结点(右子树根结点)的引用

相关推荐
代码中介商7 分钟前
数据结构开篇:从问题到解决方案
数据结构
EnCi Zheng24 分钟前
M5-markconv自定义CSS样式指南 [特殊字符]
前端·css·python
kyriewen28 分钟前
你的网页慢,用户不说直接走——前端性能监控教你“读心术”
前端·性能优化·监控
广州华水科技29 分钟前
北斗GNSS变形监测在大坝安全监测中的应用与优势分析
前端
前端老石人40 分钟前
前端开发中的 URL 完全指南
开发语言·前端·javascript·css·html
CAE虚拟与现实41 分钟前
五一假期闲来无事,来个前段、后端的说明吧
前端·后端·vtk·three.js·前后端
AKDreamer_HeXY44 分钟前
QOJ 12255 - 36 Puzzle 题解
数据结构·c++·数学·算法·icpc·qoj
Sarvartha1 小时前
三目运算符
linux·服务器·前端
晓晨的博客1 小时前
ROS1录制的bag包转换为ROS2格式
前端·chrome
Wect1 小时前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·typescript