leetcode206-反转链表

leetcode 206

思路

考虑使用双指针的方式来进行反转,定义一个pre指针,指向需要反转的位置,cur指针代表当前位置,一层层进行反转,中间需要一个临时指针也就是代码中的node,因为一旦反转,之前的链路就断开了,比如cur.next = pre设置以后,原来的cur.next就找不到了,所以需要设置一个临时指针保存原本的cur.next,这样才能继续下一步操作

图片来自代码随想录

实现

js 复制代码
var reverseList = function (head) {
  let cur = head;
  let pre = null;
  while (cur) {
    let node = cur.next;
    cur.next = pre;
    pre = cur;
    cur = node;
  }
  return pre;
};
相关推荐
星火开发设计12 小时前
类模板:实现通用数据结构的基础
java·开发语言·数据结构·c++·html·知识
EE工程师12 小时前
数据结构篇 - 顺序队列
数据结构·顺序队列
白中白1213812 小时前
算法题-14
数据结构·算法·leetcode
2501_9011478312 小时前
打家劫舍问题的动态规划解法与性能优化笔记
笔记·算法·动态规划
plus4s13 小时前
2月13日(73-75题)
数据结构·c++·算法
近津薪荼13 小时前
dfs专题8——子集
算法·深度优先
独断万古他化13 小时前
【算法通关】位运算:位图、异或消消乐,高频算法题全解
算法·位运算
你的冰西瓜13 小时前
C++ STL算法——修改序列算法
开发语言·c++·算法·stl
大黄说说13 小时前
彻底删除重复节点——LeetCode 82 题「有序链表去重 II」详解
算法·leetcode·链表
如意猴13 小时前
003【高精度算法】加法/减法/乘法/除法
算法