国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

用JavaScript實(shí)現(xiàn)功能齊全的單鏈表

Kosmos / 3151人閱讀

摘要:前言前端也要搞好數(shù)據(jù)結(jié)構(gòu)哦用實(shí)現(xiàn)了個(gè)單鏈表,通過構(gòu)造函數(shù)可實(shí)例化一個(gè)單鏈表數(shù)據(jù)結(jié)構(gòu)的對(duì)象,所有的方法放到構(gòu)造函數(shù)的原型對(duì)象上,寫了暫時(shí)能想到的所有方法源碼地址,下載可運(yùn)行實(shí)現(xiàn)通過的類創(chuàng)建鏈表實(shí)例,鏈表下有添加,查找,刪除,顯示節(jié)點(diǎn)等方法鏈表

前言

前端也要搞好數(shù)據(jù)結(jié)構(gòu)哦!!

用JavaScript實(shí)現(xiàn)了個(gè)單鏈表,通過LinkedList構(gòu)造函數(shù)可實(shí)例化一個(gè)單鏈表數(shù)據(jù)結(jié)構(gòu)的對(duì)象,所有的方法放到LinkedList構(gòu)造函數(shù)的原型對(duì)象上,寫了暫時(shí)能想到的所有方法

GitHub源碼地址,下載可運(yùn)行

實(shí)現(xiàn)

通過LinkedList的類創(chuàng)建鏈表實(shí)例,鏈表下有添加,查找,刪除,顯示節(jié)點(diǎn)等方法

鏈表初始默認(rèn)有一個(gè)"_head"頭部節(jié)點(diǎn),使用時(shí)隱藏

元素/索引 添加、刪除,未找到時(shí)返回錯(cuò)誤,查找未找到時(shí)返回null或-1

let obj = new LinkedList()

方法介紹

查找

obj.find(item)通過item元素內(nèi)容查找到該元素

obj.findIndex(index)通過index索引查找到該元素

obj.findIndexOf(item)通過item元素內(nèi)容查找到該元素索引

obj.findPrev(item)通過item元素查找上一個(gè)節(jié)點(diǎn)元素

添加

obj.insert(item,newElement)在item元素后插入新元素

obj.push(item)在鏈表末尾插入item元素

obj.insertIndex(index,newElement)在index索引處插入新元素

刪除

obj.remove(item)刪除item元素

obj.removeIndex(index)刪除index索引處節(jié)點(diǎn)

其他

obj.size()返回該鏈表的長度

obj.display()數(shù)組形式返回該鏈表,便于觀察,測(cè)試

obj.reversal()鏈表順序反轉(zhuǎn)(遞歸)

方法代碼

鏈表類LinkedList

      function LinkedList (...rest) {
        this._head = new Node("_head") // 鏈表頭節(jié)點(diǎn)
        // 如果new時(shí)有傳進(jìn)值,則添加到實(shí)例中
        if (rest.length) {
          this.insert(rest[0], "_head")
          for (let i = 1; i < rest.length; i++) {
            this.insert(rest[i], rest[i - 1])
          }
        }
      }
      LinkedList.prototype.find = find
      LinkedList.prototype.findPrev = findPrev
      LinkedList.prototype.findIndex = findIndex
      LinkedList.prototype.findIndexOf = findIndexOf
      LinkedList.prototype.push = push
      LinkedList.prototype.insert = insert
      LinkedList.prototype.insertIndex = insertIndex
      LinkedList.prototype.remove = remove
      LinkedList.prototype.removeIndex = removeIndex
      LinkedList.prototype.size = size
      LinkedList.prototype.display = display
      LinkedList.prototype.reversal = reversal

創(chuàng)建新節(jié)點(diǎn)類Node

      function Node (element) {
        this.element = element
        this.next = null
      }

obj.find(item)

// 查找函數(shù),在鏈表中查找item的位置,并把它返回,未找到返回-1
        function find (item) {
          let currNode = this._head
          while (currNode !== null && currNode.element !== item) {
            currNode = currNode.next
          }
          if (currNode !== null) {
            return currNode
          } else {
            return null
          }
        }

obj.findIndex(index)

// 通過元素的索引返回該元素
        function findIndex (index) {
          let currNode = this._head
          let tmpIndex = 0
          while (currNode !== null) {
            // 找到該index位置,返回當(dāng)前節(jié)點(diǎn),出去頭結(jié)點(diǎn)
            if (tmpIndex === index + 1) {
              return currNode
            }
            tmpIndex += 1
            currNode = currNode.next
          }
          return null
        }

obj.findIndexOf(item)

        function findIndexOf (item) {
          let currNode = this._head
          let tmpIndex = 0
          while (currNode.next !== null && currNode.next.element !== item) {
            tmpIndex += 1
            currNode = currNode.next
          }
          if (currNode !== null) {
            return tmpIndex
          } else {
            return -1
          }
        }

obj.findPrev(item)

// 尋找目標(biāo)節(jié)點(diǎn)item的上一個(gè)節(jié)點(diǎn),未找到返回-1
        function findPrev (item) {
          let currNode = this._head
          while (currNode.next !== null && currNode.next.element !== item) {
            currNode = currNode.next
          }
          if (currNode.next !== item) {
            return currNode
          } else {
            return null
          }
        }

obj.insert(item,newElement)

// 插入節(jié)點(diǎn),找到要插入到的item的節(jié)點(diǎn)位置,把新節(jié)點(diǎn)插到item后面
        function insert (newElement, item) {
          let newNode = new Node(newElement)
          let currNode = this.find(item)
          if (currNode) {
            newNode.next = currNode.next
            currNode.next = newNode
          } else {
            console.error(`insert error:鏈表中不存在「${item}」節(jié)點(diǎn)`)
          }
        }

obj.insertIndex(index,newElement)

// 插入節(jié)點(diǎn),新節(jié)點(diǎn)插到index索引下
        function insertIndex (newElement, index) {
          let newNode = new Node(newElement)
          let currNode = this.findIndex(index)
          if (currNode) {
            newNode.next = currNode.next
            currNode.next = newNode
          } else {
            console.error(`insertIndex error:鏈表中不存在「${index}」索引節(jié)點(diǎn)`)
          }
        }

obj.push(item)

// 在鏈表最后一位添加元素
        function push (element) {
          let newNode = new Node(element)
          let currNode = this._head
          while (currNode.next !== null) {
            currNode = currNode.next
          }
          currNode.next = newNode
        }

obj.remove(item)

// 刪除節(jié)點(diǎn),找到刪除的位置,刪除,未找到提示錯(cuò)誤
        function remove (item) {
          // 找到當(dāng)前和上一個(gè)節(jié)點(diǎn),讓上一個(gè)節(jié)點(diǎn)的next指向item下一個(gè)節(jié)點(diǎn)
          let tmpPrev = this.findPrev(item)
          let tmpNext = this.find(item)
          if (tmpPrev && tmpNext) {
            tmpPrev.next = tmpNext.next
          } else {
            console.error(`remove error:鏈表中不存在「${item}」節(jié)點(diǎn)`)
          }
        }

obj.removeIndex(index)

// 刪除某個(gè)索引下的節(jié)點(diǎn)
        function removeIndex (index) {
          let tmpPrev = this.findIndex(index - 1)
          let currNode = this.findIndex(index)
          if (tmpPrev && currNode) {
            tmpPrev.next = currNode.next
          } else {
            console.error(`removeIndex error:鏈表中不存在「${index}」索引節(jié)點(diǎn)`)
          }
        }

obj.size()

        function size () {
          let currNode = this._head
          let tmpSize = 0
          while (currNode.next !== null) {
            tmpSize += 1
            currNode = currNode.next
          }
          return tmpSize // 不計(jì)算頭部節(jié)點(diǎn)
        }

obj.reversal()

      // 鏈表反轉(zhuǎn)=>遞歸
      function reversal () {
        function reversalList (item) {
          if (item.next) {
            let tmpItem = reversalList(item.next)
            item.next = null
            tmpItem.next = item
            return item
          } else {
            obj._head.next = item
            return item
          }
        }
        reversalList(obj._head.next)
      }

obj.display()

        function display () {
          // 鏈表展示和使用,默認(rèn)頭部不存在
          let currNode = this._head.next
          let tmpArr = []
          while (currNode !== null) {
            tmpArr.push(currNode)
            currNode = currNode.next
          }
          return tmpArr
        }
實(shí)例測(cè)試
      // 運(yùn)行測(cè)試
      let obj = new LinkedList("節(jié)點(diǎn)0", "節(jié)點(diǎn)1", "節(jié)點(diǎn)2", "節(jié)點(diǎn)3", "節(jié)點(diǎn)4", "節(jié)點(diǎn)5")
      console.log("---實(shí)例對(duì)象")
      console.log(obj)
      console.log("---末尾插入元素")
      obj.push("push插入")
      console.log(obj.display())
      console.log("---元素后插入元素")
      obj.insert("元素插入", "節(jié)點(diǎn)2")
      console.log(obj.display())
      console.log("---索引處插入元素")
      obj.insertIndex("索引插入", 5)
      console.log(obj.display())
      console.log("---查找元素位置")
      console.log(obj.find("節(jié)點(diǎn)4"))
      console.log("---移除元素")
      obj.remove("節(jié)點(diǎn)5")
      console.log(obj.display())
      console.log("---移除索引元素")
      obj.removeIndex(5)
      console.log(obj.display())
      console.log("---元素長度")
      console.log(obj.size())
      console.log("---索引查找")
      console.log(obj.findIndex(2))
      console.log("---元素查找索引")
      console.log(obj.findIndexOf("節(jié)點(diǎn)3"))
      console.log("---反轉(zhuǎn)鏈表")
      obj.reversal()
      console.log(obj.display())
測(cè)試結(jié)果

結(jié)尾

最近遇到單鏈表反轉(zhuǎn)的問題,所有加了一個(gè)單鏈表反轉(zhuǎn)的方法,用遞歸實(shí)現(xiàn)

相關(guān)鏈接

實(shí)現(xiàn)單鏈表反轉(zhuǎn)的幾種方法
如何用JavaScript實(shí)現(xiàn)一個(gè)功能齊全的單鏈表

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/101544.html

相關(guān)文章

  • 【譯】JavaScript數(shù)據(jù)結(jié)構(gòu)(3):單向鏈與雙向鏈

    摘要:計(jì)算機(jī)科學(xué)中最常見的兩種數(shù)據(jù)結(jié)構(gòu)是單鏈表和雙鏈表。雙向鏈表雙向鏈表具有單鏈表的所有功能,并將其擴(kuò)展為在鏈表中可以進(jìn)行雙向遍歷。雙向鏈表的操作我們的鏈表將包括兩個(gè)構(gòu)造函數(shù)和。與單鏈表不同,雙向鏈表包含對(duì)鏈表開頭和結(jié)尾節(jié)點(diǎn)的引用。 翻譯:瘋狂的技術(shù)宅英文:https://code.tutsplus.com/art...說明:本文翻譯自系列文章《Data Structures With Ja...

    Chiclaim 評(píng)論0 收藏0
  • 數(shù)據(jù)結(jié)構(gòu)JavaScript描述(二)

    摘要:在上一篇文章中,我們了解了隊(duì)列和棧的描述,現(xiàn)在讓我們來了解一下單鏈表和雙向鏈表的實(shí)現(xiàn)。單鏈表和雙向鏈表具有以下特點(diǎn)可動(dòng)態(tài)分配空間,但不能隨機(jī)訪問。 在上一篇文章中,我們了解了隊(duì)列和棧的JavaScript描述,現(xiàn)在讓我們來了解一下 單鏈表 和雙向鏈表 的實(shí)現(xiàn)。本文的代碼并非所有都由本人所寫,只是出于學(xué)習(xí)目的,在此分享出來,并加上一定的解釋,便于大家學(xué)習(xí)。 本系列文章的代碼可在ht...

    OldPanda 評(píng)論0 收藏0
  • 單鏈(LinkedList)javascript實(shí)現(xiàn)

    摘要:相關(guān)庫編程思路方法用于將元素追加到鏈表尾部,借由方法來實(shí)現(xiàn)注意各個(gè)函數(shù)的邊界條件處理。自己的實(shí)現(xiàn)源代碼地址 起因 最近在看《數(shù)據(jù)結(jié)構(gòu)與算法--javascript描述》,然后上npmjs.org去搜索,想找合適的庫參考并記錄下來,以備以后用時(shí)能拿來即用,最沒有發(fā)現(xiàn)很合自己意的,于是就決定自己一一實(shí)現(xiàn)出來。 npmjs相關(guān)庫 complex-list、smart-list、singly-...

    王陸寬 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<