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;
};
相关推荐
l1t2 分钟前
DeepSeek总结的算法 X 与舞蹈链文章
前端·javascript·算法
gihigo19983 分钟前
水声信号处理中DEMON谱分析的原理、实现与改进
算法·信号处理
歌_顿9 分钟前
微调方法学习总结(万字长文!)
算法
@小码农15 分钟前
202512 电子学会 Scratch图形化编程等级考试四级真题(附答案)
java·开发语言·算法
mit6.82429 分钟前
右端点对齐|镜像复用
算法
denggun123452 小时前
悬垂指针 和 野指针
数据结构
Pluto_CSND2 小时前
JSONPath解析JSON数据结构
java·数据结构·json
无限进步_2 小时前
【C语言】用队列实现栈:数据结构转换的巧妙设计
c语言·开发语言·数据结构·c++·链表·visual studio
Xの哲學2 小时前
从硬中断到 softirq:Linux 软中断机制的全景解剖
linux·服务器·网络·算法·边缘计算
liu****2 小时前
02_Pandas_数据结构
数据结构·python·pandas·python基础