leetcode707-设计链表

embedded/2025/1/19 9:46:29/

leetcode 707
在这里插入图片描述

思路

本题也是用了虚拟头节点来进行解答,这样的好处是,不管是头节点还是中间的节点都可以当成是中间节点来处理,用同一套方法就可以进行处理,而不用考虑太多的边界条件。
下面题目中最主要的实现就是添加操作addAtIndex和删除操作deleteAtIndex,对于在头节点和尾节点添加其实都是调用添加方法就可以,头节点设置index = 0, 尾节点设置index = size

get

获取某个节点值,通过循环遍历到当前节点,设置一个cur来记录每次遍历到的当前节点,然后返回cur.val

add

我们要添加的时候一定需要找到的是索引的前一个节点,因为这样才可以进行添加,如果找成了后一个节点,那么我们由于这里设置的是单向链表,就无法再去索引到前一个节点,也就没办法进行连接,找到了前一个节点之后,需要先把要添加到节点设置为cur.next,然后再设置cur.next = node; ,注意这里顺序一定不能错,一旦先把cur.next 设置为node以后,原先的cur.next就断掉,node.next就无法继续设置

delete

这里删除操作可以参考前一篇的博文:移除链表元素
不过这里的删除操作会更简单一些,总的来说就是跳过需要删除的节点,把cur.next 设置为cur.next.next

实现

// 创建链表节点
class CreateNode{constructor(val,next){this.val = val ?? 0;this.next = next ?? null;}
}var MyLinkedList = function() {this.size = 0;this.dummy = new CreateNode(0);
};/** 
获取下标为index的值* @param {number} index* @return {number}*/
MyLinkedList.prototype.get = function(index) {if(index < 0 || index >= this.size) return -1;let cur = this.dummy.next;for(let i = 0; i < index;i++){cur = cur.next}return cur.val;
};/** 
添加到头节点* @param {number} val* @return {void}*/
MyLinkedList.prototype.addAtHead = function(val) {this.addAtIndex(0,val);
};/** 
添加到尾节点* @param {number} val* @return {void}*/
MyLinkedList.prototype.addAtTail = function(val) {this.addAtIndex(this.size,val);
};/** 
添加到index节点前* @param {number} index * @param {number} val* @return {void}*/
MyLinkedList.prototype.addAtIndex = function(index, val) {if(index < 0 || index > this.size) return;// 可以进行添加,size++this.size++;let cur = this.dummy;for(let i = 0;i<index;i++){cur = cur.next;}// 进行添加操作const node = new CreateNode(val);node.next = cur.next;cur.next = node;
};/** 
删除节点* @param {number} index* @return {void}*/
MyLinkedList.prototype.deleteAtIndex = function(index) {if(index >= this.size || index < 0) return;// 可以进行删除,长度size-1this.size--// 获取到可删除的节点的前一个节点let cur = this.dummy;for(let i = 0;i<index;i++){cur=cur.next;}// 删除操作cur.next = cur.next.next
};

http://www.ppmy.cn/embedded/155184.html

相关文章

Python球球大作战

系列文章 序号直达链接表白系列1Python制作一个无法拒绝的表白界面2Python满屏飘字表白代码3Python无限弹窗满屏表白代码4Python李峋同款可写字版跳动的爱心5Python流星雨代码6Python漂浮爱心代码7Python爱心光波代码8Python普通的玫瑰花代码9Python炫酷的玫瑰花代码10Python多…

数据结构-ArrayList和顺序表

1.线性表 线性表是n个具有相同类型的数据元素所组成的有限序列&#xff0c;当n0时&#xff0c;线性表为一个空表。 常见的线性表&#xff1a;顺序表&#xff0c;链表&#xff0c;栈和队列... 线性表在逻辑上是线性结构&#xff0c;可以说是连续的一条直线。但是在物理结构上…

在服务器上增加新网段IP的路由配置

在服务器上增加新网段IP的路由配置 前提条件步骤一:检查当前路由表步骤二:添加新路由步骤三:验证新路由步骤四:持久化路由配置脚本示例结论在网络管理中,路由配置是一项基本且重要的任务。它决定了数据包在网络中的传输路径。本文将详细介绍如何在服务器上增加新的路由配置…

【2025 Rust学习 --- 18 IO操作和网络】

输入与输出 Rust 标准库中的输入和输出的特性是围绕 3 个特型组织的&#xff0c;即 Read、 BufRead 和 Write。 实现了 Read 的值具有面向字节的输入方法。它们叫作读取器。实现了 BufRead 的值是缓冲读取器。它是 Read的子特型 &#xff0c;外加读取文本行等方法。实现了 Wr…

正态分布检验(JB检验和威尔克检验)和斯皮尔曼相关系数(继上回)

正态分布的检验 1,JB检验(n>30) (1)偏度和峰度 描述函数正不正&#xff0c;高不高的 Matlab中计算偏度和峰度的函数是&#xff1a;skewness() 和 kurtosis() 我们以normrnd来生成一个100*1的均值为2,标准差为3的正态分布(这里采用的第一个公式) 得到下面的数据,因为这个…

介绍下常用的前端框架及时优缺点

以下是一些常用的前端框架及其优缺点介绍&#xff1a; React • 优点 • 组件化架构&#xff1a;可构建可复用的UI组件&#xff0c;提高开发效率和组件可维护性。 • 虚拟DOM&#xff1a;高效更新页面&#xff0c;减少直接操作DOM的性能开销。 • 灵活性和可扩展性&#xf…

【STM32-学习笔记-12-】PWR电源控制

文章目录 PWR电源控制一、PWR简介二、STM32电源框图Ⅰ、上电复位和掉电复位Ⅱ、PVD可编程电压监测器 三、STM32的低功耗模式Ⅰ、睡眠模式&#xff08;Sleep Mode&#xff09;Ⅱ、停机模式&#xff08;Stop Mode&#xff09;Ⅲ、待机模式&#xff08;Standby Mode&#xff09; 四…

javaEE初阶————计算机是如何工作的

今天给大家带来javaEE初阶的知识&#xff0c;相信大家已经学完javaSE了吧&#xff0c;我们从本期博客开始为大家一一讲解&#xff0c;我们现在开始吧 我们作为程序员&#xff0c;大概了解这部分即可嗷 1&#xff0c;计算机的组成 祖师爷提出的&#xff1a; 冯诺依曼体系结构…