摘要:前言前端也要搞好數(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
摘要:計(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...
摘要:在上一篇文章中,我們了解了隊(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...
摘要:相關(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-...
閱讀 1168·2023-04-26 01:35
閱讀 2561·2021-11-02 14:44
閱讀 7692·2021-09-22 15:38
閱讀 2246·2021-09-06 15:11
閱讀 3735·2019-08-30 15:53
閱讀 841·2019-08-29 16:54
閱讀 669·2019-08-26 13:48
閱讀 1783·2019-08-26 13:47