前端面试题——JS实现反转链式表

前言

反转单向链表就是将整个单链表的数据进行倒序的过程。

例如,如果反转之前的单链表是0->1->2->3,那么反转之后的单链表应该是3->2->1->0。这个操作通常是通过改变链表中每个节点的指针方向来实现的,即让每个节点的指针指向其前一个节点,而不是下一个节点。这种操作不需要开辟新的内存空间,只需要通过改变指针的指向即可完成。

实现原理

在反转单向链表的过程中,通常需要使用三个指针,分别是:指向当前节点的指针,指向当前节点前一个节点的指针,以及临时存储当前节点下一个节点的指针。然后,从链表的第二个节点开始遍历,将当前节点的指针指向前一个节点,同时更新前一个节点和下一个节点的指针,直到遍历到链表的最后一个节点,此时整个链表就被反转了。

代码实现

步骤1

首先定义两个指针,指向当前节点以及指向当前节点前一个节点。

let current = head;let prev = null;

步骤2

定义记录 p1 指针的next的临时指针

const nextTemp = current.next; 

步骤3

然后,我们编写一个函数来反转链表

function reverseLinkedList(head) {  let prev = null; // 前一个节点,初始化为null  let current = head; // 当前节点,从链表的头节点开始  while (current !== null) {  // 保存当前节点的下一个节点  const nextTemp = current.next;  // 修改当前节点的next指向prev  current.next = prev;  // 将prev和current向前移动一步  prev = current;  current = nextTemp;  }  // 反转后,原链表的头节点成为尾节点,其值为null  // 新的头节点是prev  return prev;  
}

方法的使用

定义一个链表节点类

class ListNode {  constructor(val, next = null) {  this.val = val;  this.next = next;  }  
}

接下来,我们可以创建一些节点并连接它们来形成一个链表,然后调用 reverseLinkedList 函数来反转这个链表:

// 创建链表: 1 -> 2 -> 3  
const node3 = new ListNode(3);  
const node2 = new ListNode(2, node3);  
const node1 = new ListNode(1, node2);  // 打印原始链表  
let current = node1;  
while (current !== null) {  console.log(current.val);  current = current.next;  
}  // 打印结果:1 2 3// 反转链表  
const reversedHead = reverseLinkedList(node1);  // 打印反转后的链表  
current = reversedHead;  
while (current !== null) {  console.log(current.val);  current = current.next;  
}
// 打印结果:3 2 1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/466182.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HCIA-HarmonyOS设备开发认证V2.0-3.2.轻量系统内核基础-中断管理

目录 一、中断基础概念二、中断管理使用说明三、中断管理模块接口四、代码分析(待续...) 一、中断基础概念 在程序运行过程中,出现需要由 CPU 立即处理的事务时,CPU 暂时中止当前程序的执行转而处理这个事务,这个过程…

KingSCADA实现按钮点击效果

哈喽,你好啊,我是雷工! 在做SCADA项目的时候,按钮是不可缺少的功能,但软件自带的按钮太丑,已经无法满足现如今客户对界面美观度的要求。 这时候就需要UI小姐姐设计美观大气的SCADA界面,但UI设计…

车载诊断协议DoIP系列 —— 协议中术语解释和定义

车载诊断协议DoIP系列 —— 协议中术语解释和定义 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师(Wechat:gongkenan2013)。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 本就是小人物,输了就是输了,不要在意别人怎么看自己。江湖一碗茶,…

小周带你正确理解Prompt-engineering,RAG,fine-tuning工程化的地位和意义

有人会说:"小周,几天不见这么拉了,现在别说算法了,连code都不讲了,整上方法论了。" 我并没有拉!而且方法论很重要,尤其工程化的时候,你总得知道每种技术到底适合干啥&…

政安晨:演绎在KerasCV中使用Stable Diffusion进行高性能图像生成

小伙伴们好,咱们今天演绎一个使用KerasCV的StableDiffusion模型生成新的图像的示例。 考虑计算机性能的因素,这次咱们在Colab上进行,Colab您可以理解为在线版的Jupyter Notebook,还不熟悉Jupyter的的小伙伴可以去看一下我以前的文…

Linux中FIFO管道

介绍: FIFO被称为命名管道,pipe只能用于有血缘关系的进程间通信,但通过FIFO,不相关的进程也可以进程间通信。 FIFO是linux基础文件类型的一种(文件类型为p),FIFO文件在磁盘上没有数据块&#…

3秒实现无痛基于Stable Diffusion WebUI安装ComfyUI!无需重复安装环境!无需重复下载模型!安装教程

标题略有夸张哈哈哈哈,但想表达的是,相较于直接下载或者通过秋叶包更新而,接下来这一套方案确实很简单,而且能够 大大节省磁盘空间,和下载时间。 这篇教程不需要你有: 代码基础。都是复制粘贴就完事。魔法…

windows 下安装gin

go install 执行命令,执行不了的参考一下 https://blog.csdn.net/weixin_42592326/article/details/135946806 Golang 中没法下载第三方包解决办法-CSDN博客 go install github.com/gin-gonic/ginlatest 还是安装不了的话,用手机开热点,电…

肿瘤浸润性巨噬细胞的复杂作用(综述浏览)

The complex role of tumor-infiltrating macrophages - PubMed (nih.gov) 长期以来,人们一直认为巨噬细胞是一种进化古老的细胞类型,参与组织稳态和对病原体的免疫防御,但现在人们又发现巨噬细胞是包括癌症在内的多种疾病的调节因子。肿瘤相…

Apache 神禹(shenyu)源码阅读(一)——Admin向Gateway的数据同步(Admin端)

源码版本:2.6.1 单机源码启动项目 启动教程:社区新人开发者启动及开发防踩坑指南 源码阅读 前言 开了个新坑,也是第一次阅读大型项目源码,写文章记录。 在写文章前,已经跑了 Divide 插件体验了一下(体…

【十五】【C++】list的简单实现

list 的迭代器解引用探究 /*list的迭代器解引用探究*/ #if 1 #include <list> #include <vector> #include <iostream> #include <algorithm> using namespace std;class Date {private:int _year;int _month;int _day;public:Date(): _year(2024), _m…

Stable Diffusion 模型下载:majicMIX reverie 麦橘梦幻

本文收录于《AI绘画从入门到精通》专栏,专栏总目录:点这里。 文章目录 模型介绍生成案例案例一案例二案例三案例四案例五案例六案例七案例八案例九案例十