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;
};
相关推荐
eso19831 分钟前
白话讲述监督学习、非监督学习、强化学习
算法·ai·聚类
chen_jared3 分钟前
反对称矩阵的性质和几何意义
人工智能·算法·机器学习
海天一色y16 分钟前
python---力扣数学部分
算法·leetcode·职场和发展
一起努力啊~22 分钟前
算法刷题--哈希表
算法·面试·散列表
willingli27 分钟前
c语言经典100题 61-70题
c语言·开发语言·算法
我是小疯子6632 分钟前
深入解析C++右值引用与移动语义
java·开发语言·算法
踩坑记录34 分钟前
leetcode hot100 56.合并区间 medium
leetcode
源代码•宸42 分钟前
Golang原理剖析(Map 源码梳理)
经验分享·后端·算法·leetcode·golang·map
程序员-King.44 分钟前
day132—链表—K个一组翻转链表(LeetCode-25)
leetcode·链表·贪心算法
Narrastory1 小时前
手把手实现蚁群算法:从数学原理到代码实践
算法