js数据结构和算法-----链表

链表像是一个火车,每一个 node 就像是一节火车厢,它不仅要携带自己的信息 (item),还要与下一节火车厢相连(next)

next指向下一个节点,下一个节点的内容

(一)链表的操作

1. 插入元素 insert

2. 尾部添加元素 append

3. 获取元素索引 indexOf

4. 从链表中移除一项~remove(element) 移除 element

5. 从链表中特定 位置 移除一项~ removeAt(position) 移除position所在的项

(二)代码实现

一个连接着一个

<script>
    // 定义链表类
    var LinkedList = function () {
      var head = null // 初始化链表头为空
      var length = 0 // 初始化链表长度为0

      // 链表的每一个节点 包括本身以及下一个
      var Node = function (elememt) {
        this.elememt = elememt
        this.next = null
      }

      // 链表尾添加元素
      this.append = function (element) {
        var node = new Node(element)
        // 如果该链表没有头 那么传进来的第一项就是头
        if (head === null) {
          head = node
        } else {
          // 如果链表有头,那就把这一项放到链表末尾
          // 一个节点的next如果是null 说明这项是链表末尾
          // 从头开始查找末尾项
          var current = head
          // 有下一个节点说明不是末尾项 直到 current.next 是null 退出循环,此时current是末尾项
          while (current.next) {
            current = current.next
          }
          current.next = node // 添加到最后
        }
        length++ // 链表长度加一
      }

      // 在链表某一位置插入元素
      this.insert = function (position, element) {
        if (position < 0 || position > length - 1) {
          return
        }
        if (position === 0) {
          // 说明要替换头
          var current = head
          head = new Node(element)
          head.next = current // 插入的元素的next指向之前的头
        } else {
          var index = 0
          var current = head
          var insertNode = new Node(element)
          // 循环查找要插入的位置
          while (index < position - 1) { // index 从 0 开始 减一
            current = current.next
            index++
          }
          // 找到位置 其后插入元素
          var nextNode = current.next
          current.next = insertNode
          insertNode.next = nextNode
        }
        length++
      }

      // 获取元素的索引
      this.getIndex = function (elememt) {
        var index = 0;
        var current = head
        while (index < length) {
          if (elememt === current.elememt) {
            return index
          } else {
            current = current.next
            index++
          }
        }
        // 没找到 返回 -1
        return -1
      }

      // 移除某一位置的元素
      this.removeAt = function (position) {
        if (position < 0 || position > length - 1) {
          return
        }
        if (position === 0) {
          // 换头
          head = head.next
        } else {
          var index = 0
          var current = head
          while(index < position - 1) {
            current = current.next
            index++
          }
          current.next = current.next.next
        }
        length--
      }

      // 获取链表
      this.getHead = function () {
        return head
      }

      this.removeElement = function (element) {
        // 代码复用 找 index 删除
        var index = this.getIndex(element)
        this.removeAt(index)
      }

      // 链表长度
      this.size = function () {
        return length
      }

      this.isEmpty = function () {
        return length === 0
      }
    }

    var link = new LinkedList()
    link.append(1)
    link.append(2)
    link.append(3)
    link.insert(2, 5) // 5是第三项 从0开始数数
    link.removeAt(3)
    link.removeElement(1)
    console.log(link.getHead())
    console.log(link.size())
    console.log(link.isEmpty())
    console.log(link.getIndex(5))
    // console.log(link.getHead())
  </script>

双向链表:

循环链表:

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值