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;
};
相关推荐
しかし11811420 分钟前
C语言队列的实现
c语言·开发语言·数据结构·数据库·经验分享·链表
Java致死1 小时前
费马小定理
算法·费马小定理
owde1 小时前
数据结构-顺序表
数据结构·线性表·定长顺序表·不定长顺序表
不吃元西1 小时前
leetcode 74. 搜索二维矩阵
算法·leetcode·矩阵
小开不是小可爱2 小时前
leetcode_454. 四数相加 II_java
java·数据结构·算法·leetcode
aaaweiaaaaaa2 小时前
蓝桥杯c ++笔记(含算法 贪心+动态规划+dp+进制转化+便利等)
c语言·数据结构·c++·算法·贪心算法·蓝桥杯·动态规划
Hesse2 小时前
希尔排序:Python语言实现
python·算法
h^hh3 小时前
pipe匿名管道实操(Linux)
数据结构·c++·算法
dr李四维3 小时前
解决缓存穿透的布隆过滤器与布谷鸟过滤器:谁更适合你的应用场景?
redis·算法·缓存·哈希算法·缓存穿透·布隆过滤器·布谷鸟过滤器
亓才孓3 小时前
[leetcode]01背包问题
算法·leetcode·职场和发展