Mari kita bincangkan tentang menyelak senarai terpaut dalam golang

PHPz
Lepaskan: 2023-04-23 13:56:30
asal
459 orang telah melayarinya

Senarai terpaut ialah struktur data asas, yang terdiri daripada beberapa nod Setiap nod mengandungi medan data dan penunjuk ke nod seterusnya. Dalam pengaturcaraan, selalunya perlu untuk beroperasi pada senarai terpaut, dan salah satu operasi paling asas ialah membalik senarai terpaut.

Membalikkan senarai terpaut bermakna membalikkan susunan nod dalam senarai terpaut. Sebagai contoh, senarai terpaut asal ialah 1->2->3->4, tetapi selepas membalikkannya, ia menjadi 4->3->2->1. Dalam aplikasi praktikal, menyelak senarai terpaut boleh digunakan untuk menyelesaikan beberapa masalah, seperti mencetak elemen dalam senarai terpaut, mencari nod perantaraan senarai terpaut, menentukan sama ada terdapat kitaran dalam senarai terpaut, dsb.

Dalam artikel ini, kami akan memperkenalkan cara menggunakan bahasa pengaturcaraan golang untuk melaksanakan membalik senarai terpaut. Mula-mula, kita perlu mentakrifkan struktur Nod bagi nod senarai terpaut:

type Node struct {
    Value int
    Next *Node
}
Salin selepas log masuk

Dalam struktur ini, Nilai mewakili data yang disimpan dalam nod senarai terpaut, dan Seterusnya ialah penunjuk ke nod seterusnya. Selepas mempunyai struktur nod, kita boleh mentakrifkan struktur senarai terpaut:

type List struct {
    Head *Node
}
Salin selepas log masuk

Dalam struktur ini, Head ialah penunjuk kepada nod kepala senarai terpaut.

Seterusnya, mari lihat kod untuk cara melaksanakan senarai terbalik terpaut:

func (l *List) Reverse() {
    if l.Head == nil || l.Head.Next == nil {
        return
    }

    var prev *Node
    current := l.Head
    for current != nil {
        next := current.Next
        current.Next = prev
        prev = current
        current = next
    }
    l.Head = prev
}
Salin selepas log masuk

Dalam kod ini, tentukan dahulu sama ada senarai terpaut kosong atau hanya mempunyai satu nod . Jika ya, Kembali terus tanpa membalikkan. Jika tidak, tentukan dua penunjuk, sebelum dan semasa, yang masing-masing menunjuk ke nod sebelumnya dan nod semasa senarai terpaut. Dalam gelung, mula-mula simpan nod di sebelah nod semasa, halakan nod semasa ke nod sebelumnya, dan kemudian gerakkan penunjuk ke belakang. Akhir sekali, halakan kepala senarai terpaut ke nod terakhir sebelum sebalik selepas flip.

Seterusnya, mari kita lihat contoh lengkap untuk lebih memahami proses membalik senarai terpaut:

package main

import "fmt"

type Node struct {
    Value int
    Next *Node
}

type List struct {
    Head *Node
}

func (l *List) Add(value int) {
    node := &Node{Value: value, Next: l.Head}
    l.Head = node
}

func (l *List) Reverse() {
    if l.Head == nil || l.Head.Next == nil {
        return
    }

    var prev *Node
    current := l.Head
    for current != nil {
        next := current.Next
        current.Next = prev
        prev = current
        current = next
    }
    l.Head = prev
}

func (l *List) Print() {
    var node *Node
    for node = l.Head; node != nil; node = node.Next {
        fmt.Print(node.Value, "->")
    }
    fmt.Println()
}

func main() {
    l := &List{}
    l.Add(1)
    l.Add(2)
    l.Add(3)
    l.Add(4)

    fmt.Println("Original List:")
    l.Print()

    l.Reverse()

    fmt.Println("Reversed List:")
    l.Print()
}
Salin selepas log masuk

Dalam contoh ini, kami mentakrifkan senarai terpaut l, kepada 4 nod ditambahkan pada ia, kemudian terbalik dan keluarkan. Keputusan yang dijalankan adalah seperti berikut:

Original List:
4->3->2->1->
Reversed List:
1->2->3->4->
Salin selepas log masuk

Seperti yang anda lihat, proses menyelak senarai terpaut adalah sangat mudah Anda hanya perlu mengulang senarai terpaut dan membalikkan penunjuk satu demi satu.

Dalam aplikasi praktikal, menyelak senarai terpaut adalah masalah yang sangat biasa, jadi anda perlu menguasai kemahiran ini. Saya harap artikel ini dapat membantu pembaca lebih memahami proses menyelak senarai terpaut dan kemahiran pengaturcaraan yang berkaitan.

Atas ialah kandungan terperinci Mari kita bincangkan tentang menyelak senarai terpaut dalam golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!