数据结构引论

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

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

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

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

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

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

数据域

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

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

相关推荐
daad7772 小时前
WSL2_wifi驱动安装
开发语言·前端·javascript
历程里程碑2 小时前
1 . Git本地操作:版本控制 跨平台协作 仓库核心
java·开发语言·数据结构·c++·git·gitee·github
ZC跨境爬虫2 小时前
Scrapy实战爬取5sing网站:Pipeline优化+全流程踩坑复盘,从报错到数据落地
前端·爬虫·python·scrapy
牛马1112 小时前
Flutter BoxDecoration
前端·javascript·flutter
像素猎人2 小时前
大学算法类竞赛的常用模板【自己总结+收录的】【c++版】
数据结构·算法·排序算法·算法竞赛常用算法
M ? A3 小时前
VuReact 编译器核心重构:统一管理组件元数据收集
前端·javascript·vue.js·react.js·重构·开源
山海AI手册3 小时前
030、AI应用前端展示:Streamlit快速构建交互式Web应用
前端·人工智能
专注VB编程开发20年3 小时前
C#异步状态机,内部的信号机制TaskCompletionSource
前端
cpp_25013 小时前
P1910 L 国的战斗之间谍
数据结构·c++·算法·题解·洛谷·背包dp