欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

數(shù)據(jù)結(jié)構(gòu)TypeScript之鏈表實現(xiàn)詳解

 更新時間:2023年01月30日 09:40:59   作者:前端技術(shù)獺  
這篇文章主要為大家介紹了數(shù)據(jù)結(jié)構(gòu)TypeScript之鏈表實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

鏈表結(jié)構(gòu)特點

鏈表線性表的其中一種,用于存儲有固定順序的元素。而元素之間會通過”鏈“連接在一起。

鏈表存儲的元素稱為節(jié)點。每個節(jié)點內(nèi)部存在兩個值。如下:

  • this.element:鏈表需要存儲的單個元素
  • this.next:指向下一個節(jié)點,也就是鏈表中的”鏈“,將節(jié)點連接在一起。

嘗試手動構(gòu)建鏈表結(jié)構(gòu)。過程如下:

class LinkedListNode {
    constructor(element) {
        this.element = element  // 鏈表要存儲的值
        this.next = null        // 當(dāng)前節(jié)點的下一個節(jié)點
    }
}
let A = new LinkedListNode('A') // 第一個節(jié)點A
let B = new LinkedListNode('B') // 第二個節(jié)點B
let C = new LinkedListNode('C') // 第三個節(jié)點C
// 節(jié)點之間通過this.next屬性值連起來,如下:
A.next = B // 節(jié)點A下一個是節(jié)點B
B.next = C // 節(jié)點B下一個是節(jié)點C
console.log(A) // 輸出鏈表:A -> B -> C

面向?qū)ο蠓椒ǚ庋b鏈表

構(gòu)造函數(shù)

基本單元:鏈表節(jié)點

class LinkedListNode {
    element: any
    next: (null | LinkedListNode)
    constructor(element: any) {
        this.element = element
        this.next = null
    }
}

主體:鏈表

class LinkedList {
    length: number
    head: (null | LinkedListNode)
    constructor() {
        this.length = 0
        this.head = null
    }
}

查找節(jié)點

設(shè)計一個方法,可以獲取當(dāng)前節(jié)點的前中后三個節(jié)點。這樣可以極大的方便接下來的增刪操作。如下:

getLinkedListNode(index: number): (void | { [index: number]: (null | LinkedListNode) }) {
    if (this.isEmpty()) {
        throw new Error('LinkedList is empty')
    } else if (index < 0 || index >= this.length) {
        throw new Error(`${index} does exist in [0, ${this.length})`)
    } else if (index >= 0 && index < this.length) {
        let previous: (null | LinkedListNode) = null
        let current: (null | LinkedListNode) = this.head
        for (let i = 0; i < index; i++) {
            previous = current
            current = current!.next
        }
        return { 0: previous, 1: current, 2: current!.next }
    }
}

增加節(jié)點

新節(jié)點可插入的范圍:index >= 0 && index <= this.length。也就是說,可以在每個節(jié)點的前后都可以插入新的節(jié)點。

增加節(jié)點的情況分為四種,如下分析:

  • 鏈表為空,不存在節(jié)點:直接將新節(jié)點的值賦給頭節(jié)點。
  • 在頭部之前插入節(jié)點(存在index參數(shù)且范圍符合):利用新節(jié)點的next緩存當(dāng)前頭節(jié)點,然后新節(jié)點覆蓋頭節(jié)點。
  • 在兩個節(jié)點之間插入節(jié)點(存在index參數(shù)且范圍符合):利用新節(jié)點的next緩存當(dāng)前節(jié)點,改變前一個節(jié)點的next指向新節(jié)點。
  • 在尾部插入節(jié)點:遍歷到最后一個節(jié)點,在節(jié)點末尾插入節(jié)點。
insert(element: any, index?: number): LinkedList {
    let node: (null | LinkedListNode) = new LinkedListNode(element)
    if (this.isEmpty()) {
        this.head = node
    } else if (index !== undefined && (index >= 0 && index < this.length)) {
        if (index === 0) {
            node.next = this.head
            this.head = node
        } else {
            let current: (void | object) = this.getLinkedListNode(index)
            node.next = current[0]!.next
            current[0]!.next = node
        }
    } else if (index !== undefined && (index < 0 || index > this.length)) {
        throw new Error(`${index} does exist in [0, ${this.length}]`)
    } else if (index === undefined || index === this.length) {
        let current: (null | LinkedListNode) = this.head
        while (current!.next !== null) {
            current = current!.next
        }
        current!.next = node
    }
    this.length++
    return this
}

刪除節(jié)點

鏈表節(jié)點的刪除范圍:index >= 0 && index < this.length。打個比方,鏈表長度為3,那么可刪除的位置為0,1,2。

刪除節(jié)點的情況分為三種,如下分析:

  • 刪除頭節(jié)點:鏈表長度為1,頭節(jié)點置空。鏈表長度大于1,頭節(jié)點的下一個節(jié)點覆蓋當(dāng)前頭節(jié)點。
  • 刪除中間節(jié)點(存在index參數(shù)且范圍符合):前一個節(jié)點的next直接指向當(dāng)前節(jié)點的下一個節(jié)點。
  • 刪除尾節(jié)點:找到尾節(jié)點的前一個節(jié)點,將它的next屬性置空。

注意:每次刪除都將改變鏈表的長度,而節(jié)點的刪除位置也會跟著改變。

remove(index: number): LinkedList {
    if (this.isEmpty()) {
        throw new Error('LinkedList is empty')
    } else {
        if (index === 0) {
            this.head = (this.length === 1) ? null : this.head!.next
        } else if (index > 0 && index < this.length) {
            let current: (void | object) = this.getLinkedListNode(index)
            current[0]!.next = (index + 1 === this.length) ? null : current[2]
        } else {
            throw new Error(`${index} does exist in [0, ${this.length})`)
        }
        this.length--
        return this
    }
}

本文相關(guān)代碼已放置我的Github倉庫 ??

項目地址:Algorithmlib|LinkedList

以上就是數(shù)據(jù)結(jié)構(gòu)TypeScript之鏈表實現(xiàn)詳解的詳細內(nèi)容,更多關(guān)于TypeScript數(shù)據(jù)結(jié)構(gòu)鏈表的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • CesiumJS源碼雜談之從光到?Uniform

    CesiumJS源碼雜談之從光到?Uniform

    這篇文章主要為大家介紹了CesiumJS源碼雜談之從光到Uniform的使用示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • TypeScript 基本數(shù)據(jù)類型實例詳解

    TypeScript 基本數(shù)據(jù)類型實例詳解

    這篇文章主要為大家介紹了TypeScript 基本數(shù)據(jù)類型實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • TS 中的類型推斷與放寬實例詳解

    TS 中的類型推斷與放寬實例詳解

    這篇文章主要為大家介紹了TS 中的類型推斷與放寬實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • 詳解Typescript?嚴(yán)格模式有多嚴(yán)格

    詳解Typescript?嚴(yán)格模式有多嚴(yán)格

    這篇文章主要為大家介紹了Typescript?嚴(yán)格模式有多嚴(yán)格實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • laytpl 精致巧妙的JavaScript模板引擎

    laytpl 精致巧妙的JavaScript模板引擎

    laytpl是一款顛覆性的JavaScript模板引擎,它用巧妙的實現(xiàn)方式,將自身的體積變得小巧玲瓏,不僅性能接近極致,并且還具備傳統(tǒng)前端引擎的幾乎所有功能
    2014-08-08
  • Xterm.js入門官方文檔示例詳解

    Xterm.js入門官方文檔示例詳解

    這篇文章主要為大家介紹了Xterm.js入門官方文檔示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 鮮為人知的JavaScript5個JSON秘密功能

    鮮為人知的JavaScript5個JSON秘密功能

    這篇文章主要為大家介紹了鮮為人知的JavaScript中5個JSON秘密功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • 使用JS?的download庫在瀏覽器直接下載文件

    使用JS?的download庫在瀏覽器直接下載文件

    一般情況下web項目的瀏覽器下載文件,都是使用form表單或者ajax向后端提交數(shù)據(jù),發(fā)送請求,后端文件的URL地址或者二進制文件流。這篇文章主要介紹了使用JS?的download庫在瀏覽器直接下載文件。
    2022-12-12
  • typescript類型體操及關(guān)鍵字使用示例詳解

    typescript類型體操及關(guān)鍵字使用示例詳解

    這篇文章主要為大家介紹了typescript類型體操及關(guān)鍵字使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • TypeScript中的遞歸類型示例解析

    TypeScript中的遞歸類型示例解析

    這篇文章主要為大家介紹了TypeScript中的遞歸類型示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04

最新評論