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;
};
相关推荐
雪木木7 小时前
刷题:力扣热题100--滑动窗口(Day03)
算法·leetcode
lcj25117 小时前
蓝桥杯C++:数据结构(功能导向速查)
数据结构·c++·蓝桥杯
Yzzz-F7 小时前
Problem - 2157D - Codeforces
算法
颜酱7 小时前
回溯算法实战练习(2)
javascript·后端·算法
We་ct7 小时前
LeetCode 153. 旋转排序数组找最小值:二分最优思路
前端·算法·leetcode·typescript·二分·数组
享哥7 小时前
tick 数据探索笔记:从抓取到理解
算法
禹笑笑-AI食用指南7 小时前
本地脱敏:把数据安全控制在自己手里
算法·ai·脱敏
JosieBook7 小时前
【C#】C# 中的 enum、struct 和 class 对比总结
开发语言·算法·c#
拾荒的路由7 小时前
HOT100DAY9记录用
数据结构·算法·leetcode
沙雕不是雕又菜又爱玩7 小时前
leetcode第7题 整数反转(C++)
算法·leetcode