JS中的链表(含leetcode例题)

文章目录

链表

基本特性
  • 空间上不连续
  • 每存放一个值,都要多开销一个引用空间
优点
  • 不用担心空间碎片的问题
  • 添加和删除非常容易(改节点的引用地址)
缺点
  • 查询慢
  • 每个节点创建都要创建next引用,浪费内存

传递链表要传递的是根节点

链表的每一个节点,都认为自己是根节点

js 复制代码
// 链表创建
function Node(value) {
	this.value = value;
	this.next = null
}
const a = new Node(1)
const b = new Node(2)
const c = new Node(3)

a.next = b
b.next = c
c.next = null
链表循环遍历
js 复制代码
// 链表循环遍历
function traverse(root) {
  let temp = root
  while(true) {
    if(temp != null) {
      console.log(temp.value)
    } else {
      breack;
    }
    temp = temp.next
  }
}
traverse(a)
链表递归遍历
js 复制代码
function traverse(root) {
  if(root.next === null) return;
  console.log(root.value)
  traverse(root.next)
}
链表逆置

从后往前改变指向

js 复制代码
function reversal(root) {
  if (!root.next) return root // 终止条件为到最后一个节点
  const res = reversal(root.next) // 接收最内层(最后一个节点)return的 root
  root.next.next = root // 将下一个节点指向当前节点
  root.next = null // 当前节点指向null
  return res
}
相关推荐
多米Domi0115 小时前
0x3f 第48天 面向实习的八股背诵第五天 + 堆一题 背了JUC的题,java.util.Concurrency
开发语言·数据结构·python·算法·leetcode·面试
渐暖°5 小时前
【leetcode算法从入门到精通】5. 最长回文子串
vscode·算法·leetcode
今天_也很困5 小时前
LeetCode热题100-560. 和为 K 的子数组
java·算法·leetcode
方也_arkling6 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
qq_177767376 小时前
React Native鸿蒙跨平台剧集管理应用实现,包含主应用组件、剧集列表、分类筛选、搜索排序等功能模块
javascript·react native·react.js·交互·harmonyos
v_for_van6 小时前
力扣刷题记录2(无算法背景,纯C语言)
c语言·算法·leetcode
qq_177767376 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体
web打印社区6 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
alphaTao6 小时前
LeetCode 每日一题 2026/1/26-2026/2/1
算法·leetcode