likes
comments
collection
share

"深入理解JavaScript链表:实现、操作与最佳实践"

作者站长头像
站长
· 阅读数 27

链表(Linked List)是一种数据结构,它由一系列节点组成,每个节点包含数据和一个指向下一个节点的引用。JavaScript中实现链表可以使用对象来表示节点,并通过对象的引用建立节点之间的连接。以下是关于JavaScript链表的一些基本知识:

1. 链表节点的定义:

class Node {
  constructor(data, next = null) {
    this.data = data;
    this.next = next;
  }
}

2. 链表的定义:

class LinkedList {
  constructor() {
    this.head = null;
  }
}

3. 链表操作:

  • 插入节点:

    insertFirst(data) {
      this.head = new Node(data, this.head);
    }
    
  • 删除节点:

    deleteFirst() {
      if (this.head !== null) {
        this.head = this.head.next;
      }
    }
    
  • 查找节点:

    find(data) {
      let current = this.head;
      while (current !== null) {
        if (current.data === data) {
          return current;
        }
        current = current.next;
      }
      return null;
    }
    
  • 删除指定节点:

    delete(data) {
      if (this.head === null) {
        return;
      }
      if (this.head.data === data) {
        this.head = this.head.next;
        return;
      }
      let current = this.head;
      let previous = null;
      while (current !== null && current.data !== data) {
        previous = current;
        current = current.next;
      }
      if (current === null) {
        return;
      }
      previous.next = current.next;
    }
    

4. 遍历链表:

display() {
  let current = this.head;
  while (current !== null) {
    console.log(current.data);
    current = current.next;
  }
}

在 JavaScript 中,对链表进行其他操作有很多,这取决于你的具体需求。以下是一些可能的其他操作:

1. 获取链表长度:

getLength() {
  let count = 0;
  let current = this.head;
  while (current !== null) {
    count++;
    current = current.next;
  }
  return count;
}

2. 判断链表是否为空:

isEmpty() {
  return this.head === null;
}

3. 获取链表末尾节点:

getLast() {
  let current = this.head;
  while (current !== null && current.next !== null) {
    current = current.next;
  }
  return current;
}

4. 清空链表:

clear() {
  this.head = null;
}

5. 反转链表:

reverse() {
  let current = this.head;
  let prev = null;
  let next = null;

  while (current !== null) {
    next = current.next;
    current.next = prev;
    prev = current;
    current = next;
  }

  this.head = prev;
}

6. 检测循环(是否有环):

hasCycle() {
  let slow = this.head;
  let fast = this.head;

  while (fast !== null && fast.next !== null) {
    slow = slow.next;
    fast = fast.next.next;

    if (slow === fast) {
      return true; // 有环
    }
  }

  return false; // 无环
}

7. 找到中间节点:

findMiddle() {
  let slow = this.head;
  let fast = this.head;

  while (fast !== null && fast.next !== null) {
    slow = slow.next;
    fast = fast.next.next;
  }

  return slow;
}

8. 合并两个有序链表:

mergeSortedLists(list1, list2) {
  let mergedList = new LinkedList();
  let current1 = list1.head;
  let current2 = list2.head;

  while (current1 !== null && current2 !== null) {
    if (current1.data < current2.data) {
      mergedList.insertLast(current1.data);
      current1 = current1.next;
    } else {
      mergedList.insertLast(current2.data);
      current2 = current2.next;
    }
  }

  while (current1 !== null) {
    mergedList.insertLast(current1.data);
    current1 = current1.next;
  }

  while (current2 !== null) {
    mergedList.insertLast(current2.data);
    current2 = current2.next;
  }

  return mergedList;
}

这些是一些可能的链表操作,可以根据具体需求进行扩展或修改。链表是一种非常灵活的数据结构,可以通过组合这些基本操作来实现更复杂的功能。

转载自:https://juejin.cn/post/7309549351743553573
评论
请登录