Leetcode 刷题 206. 反转链表

很多前端的同学对数据结构和算法这块没有太多的概念,很多leetcode的题目看不懂,有时候可能看了题解也不知道是什么意思。上一篇我们对链表的数据结构有了了解,下面根据题目来练习一下

206. 反转链表

题目

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

题解

其实这道题很好理解,我们拿一个例子表示:

比如我们需要将上图的链表进行反转,需要做的是将节点1的next指向节点1的前面的节点,但是节点1前面并没有节点,所以需要用到一个虚拟头节点(pre).如图:

那现在就比较好操作了,定义一个虚拟头结点pre,头节点为cur,然后将cur的next节点指向pre节点,然后再将节点pre和cur往后移动一位,进行下一次反转

下面我们来看下代码:

js 复制代码
var reverseList = function(head) {
  let cur = head
  let pre = null
  while(cur !== null ) {
    let next = cur.next
    cur.next = pre
    pre = cur
    cur = next
  }

  return pre
};

虚拟头节点为pre,头节点为cur,每一次循环则反转一个节点。首先记录下cur的下一个节点为next,然后将cur.next指向虚拟头节点pre,然后将pre和 cur往后移动。

当cur为null的时候说明链表已经到头了,则退出循环,直接返回pre即可。

还可以用es6的解构赋值优化一下

ini 复制代码
var reverseList = function (head) {
  let pre = null
  let cur = head
  while (cur) {
    [cur.next, pre, cur] = [pre, cur, cur.next]
  }
  return pre
};

欢迎大家点赞评论,大家一起学习一起进步!!!

相关推荐
得物技术14 分钟前
AI驱动:从运营行为到自动化用例的智能化实践|得物技术
前端·ai编程·全栈
前端那点事15 分钟前
Vue并发控制|几十个请求高效管控(实战方案+可运行代码)
前端·vue.js
妄想出头的工业炼药师18 分钟前
后端优化MS mapping
前端
『昊纸』℃19 分钟前
C语言学习心得集合 篇1
c语言·算法·编程基础·学习心得·实践操作
前端那点事22 分钟前
Vue大批量接口请求优化|告别卡顿、超时!前端落地实战指南
前端·vue.js
史迪仔011225 分钟前
[QML] Qt Quick Dialogs 模块使用指南
开发语言·前端·c++·qt
Chase_______25 分钟前
LeetCode 1456:定长子串中元音的最大数目
算法·leetcode
小O的算法实验室26 分钟前
2026年IEEE IOTJ,DNA序列启发相似性驱动粒子群算法+无人机与基站部署,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
谭欣辰26 分钟前
Floyd算法:动态规划解最短路径
c++·算法·图论
计算机安禾26 分钟前
【Linux从入门到精通】第12篇:进程的前后台切换与信号控制
linux·运维·算法