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
}
相关推荐
一只小阿乐10 小时前
react中的zustand 模块化
前端·javascript·react.js·react状态管理·zustand
用户842981424181010 小时前
十二个JS混淆加密工具
javascript
久爱@勿忘10 小时前
uniapp H5 图片压缩并且转blob
前端·javascript·uni-app
Dashingl10 小时前
uni-app 页面传值 报错:TypeError: $t.setAttribute is not a function
前端·javascript·uni-app
甄心爱学习10 小时前
【项目实训】法律文书智能摘要系统2
前端·javascript·vue.js
生信研究猿10 小时前
leetcode 101.对称二叉树(不会做)
算法·leetcode·职场和发展
样例过了就是过了10 小时前
LeetCode热题100 跳跃游戏 II
c++·算法·leetcode·贪心算法·动态规划
香蕉鼠片10 小时前
第三大的数
数据结构·算法·leetcode
汀、人工智能10 小时前
[特殊字符] 第28课:相交链表
数据结构·算法·链表·数据库架构··相交链表
早點睡39010 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-fs
javascript·react native·react.js