首頁 >後端開發 >Golang >go 中反轉鍊錶

go 中反轉鍊錶

WBOY
WBOY原創
2024-07-18 08:33:291154瀏覽

Reverse a linked list in go

這是新開發者最喜歡提出的問題。如果您上過像樣的資料結構課程,那麼這很簡單。

反轉單一鍊錶。 (這是 Leetcode 206)

為了實現,我選擇將鍊錶設為泛型類型。

type Node[T any] struct {
    Data T
    Next *Node[T]
}

type LinkedList[T any] struct {
    Head *Node[T]
}

func (ll *LinkedList[T]) Append(data T) {
    newNode := &Node[T]{Data: data, Next: nil}

    if ll.Head == nil {
        ll.Head = newNode
        return
    }

    current := ll.Head
    for current.Next != nil {
        current = current.Next
    }
    current.Next = newNode
}

對於反向函數,透過認識到我們需要做的就是維護指向前一個節點的指針,然後將給定節點的「下一個」設定為前一個節點,只需一次傳遞即可完成。

當我們到達末尾時,我們就知道當前節點是清單的新「頭」。

func (ll *LinkedList[T]) ReverseLinkedList() {
    var prev *Node[T] = nil
    var ptr *Node[T] = ll.Head
    for ptr != nil {
        var next *Node[T] = ptr.Next
        ptr.Next = prev
        prev = ptr
        if next == nil {
            ll.Head = ptr
        }
        ptr = next
    }
}

我們是否錯過了邊界條件?如果清單現在是雙向鍊錶,會增加哪些複雜度?請在評論中告訴我。

謝謝!

這篇文章以及本系列所有文章的程式碼可以在這裡找到

以上是go 中反轉鍊錶的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn