【JavaScript】leetcode链表相关题解
【JavaScript】leetcode链表相关题解
- 一、什么是链表?
- 二、Javascript中的链表
- 三、leetcode相关链表
- 2.两数相加
- 237.删除链表中的节点
- 206.反转链表
💎个人主页: 阿选不出来
💎个人简介: 大三学生,热爱Web前端,随机掉落学习碎片
💎目前开发的专栏: JS 🍭Vue🍭React🍭💎祝愿今天的你比昨天更加博识了!
一、什么是链表?
链表的官方定义:链表是一种物理存储单位上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。
看到这里,相信你肯定一知半解。没关系,接下来我们将链表与我们熟悉的数组进行一个对比,就好理解多了!
存储数据方面:
数组:使用一块连续的内存空间地址存放数据
链表:使用不连续的内存地址存放数据
在存储数据方面,链表相较数组更加自由,节省内存资源,更利于内存空间的利用率。
元素的查找:
数组:每个元素都有其对应的索引,可以直接通过索引访问值
链表:链表没有索引,每个链表节点至少由两部分组成:值,指向下一个节点的指针。链表的查找只能从头结点开始,顺着各个节点的指针查找。
功能:
数组与链表都能实现基本的增删改查功能。
二、Javascript中的链表
在JavaScript的数据结构中并不存在链表这一类型,但是我们可以使用Object模拟链表。
链表的常用操作:
新增节点 append | 删除节点 remove | 插入节点 insert | 获取索引 indexOf | 链表转字符换 toString | 获取链表长度 size | 获取链表是否为空 isEmpty
手撕单向链表
class Node {constructor(element){// 保存元素this.element = element;// 指向下一个节点this.next = null;}
}class LinkedList {// 构造器constructor() {this.head = null;this.length = 0;}append(element) {const newNode = new Node(element)let node = this.get(this.length - 1)if(node){node.next = newNode}else{this.head = newNode} this.length++}insert(position, element) {if(position < 0 || position > this.length) return false;let newNode = new Node(element)let prenode = this.get(position - 1)if(prenode){newNode.next = prenode.nextprenode.next = newNode}else{newNode.next = this.headthis.head = newNode}this.length++}get(position) {if(typeof position !== 'number' || position < 0 || position > this.length - 1)return null;let index = 0let position_node = this.headwhile(index++ < position){position_node = position_node.next}return position_node}indexOf(element) {let index = 0let index_node = this.headwhile(index_node){if(index_node.element === element){return index}index++;index_node = index_node.next}return -1}update(positon, element) {if(positon < 0 || positon > this.length - 1) return;const result = this.removeAt(positon)this.insert(positon, element)return result}removeAt(position) {if(position < 0|| position > this.length - 1) return;const prenode = this.get(position - 1)const current = prenode ? prenode.next : this.headif(prenode) {if(position === this.length - 1){prenode.next = null}else{prenode.next = prenode.next.next} }else{this.head = this.head.next}this.length--return current.element;} remove(element){const index = this.indexOf(element) if(index === -1) return;this.removeAt(index)}isEmpty(){return this.length === 0}size(){return this.length}toString(){let next_node = this.headlet string = ""while(next_node){string = string + next_node.element.toString()next_node = next_node.next}return string}
}
手撕双向链表
// 双向链表
class DoublyNode extends Node {constructor(element){super(element);this.prev = null}
}class DoublyLinkedList extends LinkedList {constructor(){super();this.tail = null;}// 追加append(element){let node = new DoublyNode(element)if(this.head===null){this.head = node;this.tail = node}else{node.prev = this.tailthis.tail.next = nodethis.tail = node}this.length++}// 插入节点insert(position, element){if(position<0 || position > this.length) return;const newNode = new DoublyNode(element)let node = this.get(position)if(position===0){this.head = newNodenewNode.next = nodenode.prev = newNode }else if(position===this.length){newNode.prev = this.tailthis.tail.next = newNodethis.tail = newNode}else {newNode.prev = node.prevnode.prev.next = newNodenewNode.next = nodenode.prev = newNode }this.length++}// 获取节点get(position){if(position<0 || position>this.length - 1)return falseif(position < this.length/2){let i = 0let node = this.headwhile(i++ < position){node = node.next}return node}else{let i = this.length - 1let node = this.tailwhile(i-- > position){node = node.prev}return node}}// 删除节点removeAt(position){if(position<0 || position > this.length - 1) return;const node = this.get(position)if(position === 0){if(this.length === 1){this.head = null;this.tail = null}else{this.head = node.nextnode.next.prev = null}}else if(position === this.length - 1) {this.tail = node.prevnode.next = nullnode.prev.next = null}else {node.prev.next = node.nextnode.next.prev = node.prev}this.length--}
}
三、leetcode相关链表
2.两数相加
题目描述
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
请你将两个数相加,并以相同形式返回一个表示和的链表。
你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例
输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.
提示
- 每个链表中的节点数在范围
[1, 100]内 0 <= Node.val <= 9- 题目数据保证列表表示的数字不含前导零
题解
遍历这两个链表,逐位相加,如果有进位就将目标链表下一位的节点值设为进位值并与两个链表的下一位值相加。
/*** Definition for singly-linked list.* function ListNode(val, next) {* this.val = (val===undefined ? 0 : val)* this.next = (next===undefined ? null : next)* }*/
/*** @param {ListNode} l1* @param {ListNode} l2* @return {ListNode}*/
var addTwoNumbers = function(l1, l2) {let l3 = num = new ListNode(0)while(l1 || l2){n1 = l1 ? l1.val : 0n2 = l2 ? l2.val : 0// 两数相加 + 进位数let sum = n1 + n2 + num.valif(l1){l1 = l1.next}if(l2){l2 = l2.next}num.val = sum % 10if(l1 || l2 || Math.floor(sum / 10)){num.next = new ListNode(Math.floor(sum / 10))}num = num.next}return l3
};
237.删除链表中的节点
题目描述:
有一个单链表的 head,我们想删除它其中的一个节点 node。给你一个需要删除的节点 node 。你将 无法访问 第一个节点 head。链表的所有值都是 唯一的,并且保证给定的节点 node 不是链表中的最后一个节点。
删除给定的节点。注意,删除节点并不是指从内存中删除它。这里的意思是:
- 给定节点的值不应该存在于链表中。
- 链表中的节点数应该减少 1。
node前面的所有值顺序相同。node后面的所有值顺序相同。
输入:head = [4,5,1,9], node = 5
输出:[4,1,9]
解释:指定链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9
解题思路:
删除节点的一般思路为找到要删除节点的上一节点,改变上一节点的next指针。但在本题中deleteNode函数只提供了node节点 [即要删除的节点,且无法访问head,只能访问node之后的节点],因此我们无法找到上一节点。
我们可以用node的下一个节点替换当前节点node,这样在整个链表中node也就被删除了。
var deleteNode = function(node) {node.val = node.next.val node.next = node.next.next
};
206.反转链表
题目描述:
给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
示例:
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
解题思路:
设置一个prev空链表 [保存已经逆向的链表] ,和 last 待处理链表,修改每一个节点的指针,使指针指向上一节点。
var reverseList = function(head) {let prev = null;let last = head;while(last){const next = last.nextlast.next = prevprev = lastlast = next}return prev
}
链表相关试题未完续…
相关文章:
【JavaScript】leetcode链表相关题解
【JavaScript】leetcode链表相关题解 一、什么是链表?二、Javascript中的链表三、leetcode相关链表2.两数相加237.删除链表中的节点206.反转链表 💎个人主页: 阿选不出来 💎个人简介: 大三学生,热爱Web前端,随机掉落学…...
洞察运营机会的数据分析利器
这套分析方法包括5个分析工具: 用“描述性统计”来快速了解数据的整体特点。用“变化分析”来寻找数据的问题和突破口。用“指标体系”来深度洞察变化背后的原因。用“相关性分析”来精确判断原因的影响程度。用“趋势预测”来科学预测未来数据的走势,...
使用Python实现文字的声音播放
winsound 是 Python 的一个内置模块,它提供了访问 Windows 操作系统的声音播放功能的接口。这个模块可以用来播放简单的声音,例如提示音或者短促的音效。 # Author : 小红牛 # 微信公众号:WdPython import win32com.client import winsound#…...
gulp自动化构建
什么是Gulp? Gulp是一种前端开发过程中广泛使用的自动化构建工具,它是基于Node.js构建的,能够极大地提高开发效率和代码质量。Gulp的主要功能包括文件的压缩、合并、重命名等,同时它也支持文件监听和浏览器自动刷新等功能。使用Gulp&#x…...
java时间解析生成定时Cron表达式工具类
Cron表达式工具类CronUtil 构建Cron表达式 /****方法摘要:构建Cron表达式*param taskScheduleModel*return String*/public static String createCronExpression(TaskScheduleModel taskScheduleModel){StringBuffer cronExp new StringBuffer("");if(…...
JavaEE 网络原理——TCP的工作机制(末篇 其余TCP特点)
文章目录 一、滑动窗口二、流量控制三、拥堵控制四、延时应答五、捎带应答六、面向字节流七、异常情况八、总结 其余相关文章: JavaEE 网络原理——TCP的工作机制(中篇 三次握手和四次挥手) 本篇文章衔接的是前面两篇文章的内容,在这里继续解释 TCP 的内…...
【软件测试】了解JUnit单元测试框架常用注解
目录 1、认识JUnit 2、Junit中常见的注解 1、Test 2、Disabled 3、BeforeAll和AfterAll 4、BeforeEach和AfterEach 5、 ParameterizedTest:参数化 6、order 3、断言 1、断言相等【Assertions.assertEquals(预期,比较值)】;相等测试通…...
【广州华锐互动】三维全景3D消防科普展馆
在我们的日常生活中,火灾安全是一个不容忽视的重要问题。然而,由于缺乏对火灾的了解和应对技巧,许多人在面对火灾时往往感到无助和恐慌。为了解决这个问题,广州华锐互动开发了三维全景3D消防科普展馆,它是一个以虚拟现…...
某大型车企:加强汽车应用安全防护,开创智能网联汽车新篇章
某车企是安徽省最大的整车制造企业,致力于为全球消费者带来高品质汽车产品和服务体验,是国内最早突破百万销量的汽车自主品牌。该车企利用数字技术推动供应链网络的新型互动,加快数字化转型,持续进行场景创新、生态创新…...
LLVM学习笔记(50)
4.1.4. DAG合并与合法化 来自SelectionDAGBuilder的SelectionDAG输出还不能进行指令选择,必须通过额外的转换——显示在上图。在指令选择前应用的遍序列如下: 匹配一组节点,在有利时使用更简单的构造来替换它们,DAG合并遍优化Se…...
rpc入门笔记0x01
syntax "proto3"; // 这是个proto3的文件message HelloRequest{ // 创建数据对象string name 1; // name表示名称,编号是1 }生成python文件 安装grpcio和grpcio-tools库 pip install grpcio #安装grpc pip install grpcio-tools #安装grpc tools生成…...
web - Tomcat服务器
文章目录 目录 文章目录 前言 一 . CS和BS的异同 二 . 什么是Tomcat 二 . Tomcat安装 四 . Tomcat目录结构 bin目录: 用于存放二进制的可执行文件 config目录 server.xml:配置整个服务器信息。例如修改端口号。默认HTTP请求的端口号是:8080 lib目录 log…...
后端接口返回常见的状态码
2开头 (请求成功)表示成功处理了请求的状态代码 200 (成功) 服务器已成功处理了请求。 通常,这表示服务器提供了请求的网页。 201 (已创建) 请求成功并且服务器创建了新的资源。 202 …...
50.MongoDB快速入门实战
MongoDB概念 MongoDB是一个文档数据库(以 JSON 为数据模型),由C语言编写,旨在为WEB应用提供可扩展的高性能数据存储解决方案。 原则上 Oracle 和 MySQL 能做的事情,MongoDB 都能做(包括 ACID 事务&#x…...
一款功能强大的音乐曲谱软件Guitar Pro 8 .1.1for Mac 中文破解版
Guitar Pro 8 .1.1for Mac 中文破解版是一款功能强大的音乐曲谱软件,非常适合学习如何玩,改进技巧,重现喜爱的歌曲或陪伴自己。可以帮助我们进行吉他的学习、绘谱与创作,它包含了几乎所有的吉他现有指法及音色,在做弹拨…...
图论基础和表示
一、概念及其介绍 图论(Graph Theory)是离散数学的一个分支,是一门研究图(Graph)的学问。 图是用来对对象之间的成对关系建模的数学结构,由"节点"或"顶点"(Vertex)以及连接这些顶点的"边"(Edge&a…...
STM32 音频ADC转wav格式
STM32 音频ADC DAC测试方法_stm32 adc 音频-CSDN博客 STM32--vs1053 WAV录音实现(保存在SD卡)_vs1053 多字节读取-CSDN博客 单片机内部AD实现录音wav文件_adc语音信号采样_天外飞仙CUG的博客-CSDN博客 PCM编码格式_pcm格式-CSDN博客 用ADC编码PCM数据…...
面试中经常问道的问题二
深入理解前端跨域方法和原理 前言 受浏览器同源策略的限制,本域的js不能操作其他域的页面对象(比如DOM)。但在安全限制的同时也给注入iframe或是ajax应用上带来了不少麻烦。所以我们要通过一些方法使本域的js能够操作其他域的页面对象或者使…...
SQL UPDATE 语句(更新表中的记录)
SQL UPDATE 语句 UPDATE 语句用于更新表中已存在的记录。 还可以使用AND或OR运算符组合多个条件。 SQL UPDATE 语法 具有WHERE子句的UPDATE查询的基本语法如下所示: UPDATE table_name SET column1 value1, column2 value2, ... WHERE conditi…...
js节流和防抖
节流(throttle)和防抖(debounce)是为了解决函数频繁触发而引发性能问题的两种优化方法。 节流: 指定一个时间间隔,在时间间隔内只执行一次函数,即在一段时间内,多次触发函数只执行一…...
C++实现分布式网络通信框架RPC(3)--rpc调用端
目录 一、前言 二、UserServiceRpc_Stub 三、 CallMethod方法的重写 头文件 实现 四、rpc调用端的调用 实现 五、 google::protobuf::RpcController *controller 头文件 实现 六、总结 一、前言 在前边的文章中,我们已经大致实现了rpc服务端的各项功能代…...
关于nvm与node.js
1 安装nvm 安装过程中手动修改 nvm的安装路径, 以及修改 通过nvm安装node后正在使用的node的存放目录【这句话可能难以理解,但接着往下看你就了然了】 2 修改nvm中settings.txt文件配置 nvm安装成功后,通常在该文件中会出现以下配置&…...
FastAPI 教程:从入门到实践
FastAPI 是一个现代、快速(高性能)的 Web 框架,用于构建 API,支持 Python 3.6。它基于标准 Python 类型提示,易于学习且功能强大。以下是一个完整的 FastAPI 入门教程,涵盖从环境搭建到创建并运行一个简单的…...
家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
C++ 基础特性深度解析
目录 引言 一、命名空间(namespace) C 中的命名空间 与 C 语言的对比 二、缺省参数 C 中的缺省参数 与 C 语言的对比 三、引用(reference) C 中的引用 与 C 语言的对比 四、inline(内联函数…...
工业自动化时代的精准装配革新:迁移科技3D视觉系统如何重塑机器人定位装配
AI3D视觉的工业赋能者 迁移科技成立于2017年,作为行业领先的3D工业相机及视觉系统供应商,累计完成数亿元融资。其核心技术覆盖硬件设计、算法优化及软件集成,通过稳定、易用、高回报的AI3D视觉系统,为汽车、新能源、金属制造等行…...
[免费]微信小程序问卷调查系统(SpringBoot后端+Vue管理端)【论文+源码+SQL脚本】
大家好,我是java1234_小锋老师,看到一个不错的微信小程序问卷调查系统(SpringBoot后端Vue管理端)【论文源码SQL脚本】,分享下哈。 项目视频演示 【免费】微信小程序问卷调查系统(SpringBoot后端Vue管理端) Java毕业设计_哔哩哔哩_bilibili 项…...
提升移动端网页调试效率:WebDebugX 与常见工具组合实践
在日常移动端开发中,网页调试始终是一个高频但又极具挑战的环节。尤其在面对 iOS 与 Android 的混合技术栈、各种设备差异化行为时,开发者迫切需要一套高效、可靠且跨平台的调试方案。过去,我们或多或少使用过 Chrome DevTools、Remote Debug…...
在 Visual Studio Code 中使用驭码 CodeRider 提升开发效率:以冒泡排序为例
目录 前言1 插件安装与配置1.1 安装驭码 CodeRider1.2 初始配置建议 2 示例代码:冒泡排序3 驭码 CodeRider 功能详解3.1 功能概览3.2 代码解释功能3.3 自动注释生成3.4 逻辑修改功能3.5 单元测试自动生成3.6 代码优化建议 4 驭码的实际应用建议5 常见问题与解决建议…...
