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
}
相关推荐
LDX前端校草20 分钟前
position属性值及用法
前端·javascript·面试
晓131340 分钟前
【Cocos Creator 3.x】篇——第四章 子系统
前端·javascript·游戏引擎
li-xun1 小时前
我的在线工具箱继续升级:新增 Token 计算器、AI 提示词生成器和开发者格式化工具
javascript·django·html5
ikoala1 小时前
Codex 怎么买、怎么充值?先把这两套计费搞清楚
前端·javascript·后端
前端Hardy1 小时前
一个时代结束了:npm 终于对 install 脚本下手了
前端·javascript·后端
GuWenyue2 小时前
前端异步请求踩坑?3种方式搞定Ajax数据交互,从XHR到async/await
前端·javascript·设计模式
Navigator_Z2 小时前
LeetCode //C - 1096. Brace Expansion II
c语言·算法·leetcode
笨笨没好名字3 小时前
Leetcode刷题python版第一周
python·算法·leetcode
一只齐刘海的猫3 小时前
【Leetcode】无重复字符的最长子串
算法·leetcode·职场和发展
大家的林语冰3 小时前
超越 TypeScript,Flow 强势回归,语法高仿 TS,功能更丰富,类型更安全!
前端·javascript·typescript