前端知识学习24.3.19

如何反转一个链表

三个指针,一个指向头节点,另外两个用来指向头节点前后两个节点的位置

javascript 复制代码
// 定义链表节点类
class ListNode {
  constructor(val) {
    this.val = val;
    this.next = null;
  }
}

// 定义反转链表函数
function reverseLinkedList(head) {
  let prev = null;
  let current = head;
  
  while (current !== null) {
    const nextTemp = current.next;
    current.next = prev;
    prev = current;
    current = nextTemp;
  }
  
  return prev; // 返回反转后的头节点
}

// 示例用法
const head = new ListNode(1);
head.next = new ListNode(2);
head.next.next = new ListNode(3);
head.next.next.next = new ListNode(4);
head.next.next.next.next = new ListNode(5);

console.log("原始链表:");
let current = head;
while (current !== null) {
  console.log(current.val);
  current = current.next;
}

const reversedHead = reverseLinkedList(head);

console.log("反转后的链表:");
let reversedCurrent = reversedHead;
while (reversedCurrent !== null) {
  console.log(reversedCurrent.val);
  reversedCurrent = reversedCurrent.next;
}
相关推荐
芭拉拉小魔仙5 小时前
企业级Vue项目的状态管理:从原理到实战架构
前端·vue.js·架构
恋猫de小郭5 小时前
丰田正在使用 Flutter 开发游戏引擎 Fluorite
android·前端·flutter
檀越剑指大厂6 小时前
【Elasticsearch系列廿】Logstash 学习
大数据·学习·elasticsearch
扶苏10026 小时前
Vue 3 响应式原理深度解析
前端·javascript·vue.js
NEXT066 小时前
React 性能优化:图片懒加载
前端·react.js·面试
PineappleCoder6 小时前
别让字体拖了后腿:FOIT/FOUT 深度解析与字体加载优化全攻略
前端·性能优化
NEXT066 小时前
后端跑路了怎么办?前端工程师用 Mock.js 自救实录
前端·后端·程序员
woodykissme7 小时前
渐开线圆柱齿轮几何计算全解析(一):从理论到实践的完整指南
学习·齿轮·齿轮加工
装不满的克莱因瓶8 小时前
Java7新特性:try-with-resources写法
java·前端·javascript·jdk·新特性·jdk7
Asher阿舍技术站9 小时前
【AI基础学习系列】四、Prompt基础知识
人工智能·学习·prompt