前端知识学习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;
}
相关推荐
东宇科技2 分钟前
如何使用js进行抠图。识别商品主体
开发语言·javascript·ecmascript
不会写DN4 分钟前
Vue3中的computed 与 watch 的区别
javascript·面试·vue
qq_381338505 分钟前
TypeScript 类型安全与类型体操实战:从入门到精通
javascript·安全·typescript
朦胧之17 分钟前
AI 编程工具使用浅谈
前端·后端
柳杉22 分钟前
HTML-in-Canvas:让 Canvas 完美渲染 HTML 的 Web 新标准
前端·javascript
cTz6FE7gA28 分钟前
WebGL实战:用Three.js创建3D场景,实现沉浸式Web体验
前端·javascript·webgl
chh56331 分钟前
C++--内存管理
java·c语言·c++·windows·学习·面试
We་ct39 分钟前
LeetCode 69. x 的平方根:两种解法详解
前端·javascript·算法·leetcode·typescript·平方
CNemon42 分钟前
《怎样学习文言文》溯源
学习
wayz111 小时前
21天机器学习核心算法学习计划(量化方向)
学习·算法·机器学习