Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk melaksanakan timbunan menggunakan Golang

Bagaimana untuk melaksanakan timbunan menggunakan Golang

PHPz
Lepaskan: 2023-04-11 10:17:49
asal
893 orang telah melayarinya

Golang ialah bahasa pengaturcaraan yang cekap yang mempunyai banyak struktur data untuk digunakan. Antaranya, dalam artikel ini, kita akan belajar cara menggunakan Golang untuk melaksanakan tindanan.

Dalam sains komputer, tindanan ialah struktur data yang penting. Ia adalah struktur storan Pertama Masuk Dahulu (Masuk Dahulu Terakhir), sama seperti longgokan buku Anda hanya boleh mengeluarkannya satu persatu bermula dari buku terakhir. Bagi pengaturcara komputer, timbunan boleh digunakan untuk menyelesaikan masalah berkali-kali.

Kami bermula dengan mentakrifkan operasi asas tindanan. Terdapat dua operasi asas timbunan: tolak dan pop. Operasi tolak menambah elemen pada bahagian atas tindanan, manakala operasi pop mengalih keluar elemen dari bahagian atas tindanan.

Pertama, kita perlu mentakrifkan struktur untuk mewakili timbunan:

type Stack struct {
    elements []interface{} // 存储元素的切片
    size int // 栈的大小
}
Salin selepas log masuk

Kita dapat melihat bahawa struktur ini mempunyai dua medan: elements untuk menyimpan kepingan elemen dan size mewakili saiz timbunan.

Seterusnya kita perlu melaksanakan kaedah struktur ini, termasuk push dan pop. Mula-mula laksanakan kaedah Tolak:

func (stack *Stack) Push(element interface{}) {
    stack.elements = append(stack.elements, element)
    stack.size++
}
Salin selepas log masuk

Kaedah Tekan menerima elemen sebagai parameter dan menambahkannya pada bahagian atas tindanan, dan saiznya juga ditambah satu. Anda boleh melihat bahawa pelaksanaannya adalah sangat mudah Gunakan fungsi append() untuk menambah elemen baharu pada penghujung kepingan elemen.

Seterusnya laksanakan kaedah Pop:

func (stack *Stack) Pop() (interface{}, error) {
    if stack.size == 0 {
        return nil, errors.New("stack is empty")
    }

    element := stack.elements[stack.size-1]
    stack.elements = stack.elements[:stack.size-1]
    stack.size--

    return element, nil
}
Salin selepas log masuk

Mula-mula, kita perlu menyemak sama ada tindanan kosong, dan jika ya, kembalikan ralat. Jika tidak, ambil elemen terakhir daripada kepingan, padamkan elemen itu, gunakan penghirisan tatasusunan [:stack.size-1] dan kembalikan elemen itu.

Kini, kami telah berjaya melaksanakan tindanan menggunakan Golang. Berikut ialah contoh pelaksanaan tindanan lengkap:

package main

import (
    "errors"
    "fmt"
)

type Stack struct {
    elements []interface{} 
    size int 
}

func (stack *Stack) Push(element interface{}) {
    stack.elements = append(stack.elements, element)
    stack.size++
}

func (stack *Stack) Pop() (interface{}, error) {
    if stack.size == 0 {
        return nil, errors.New("stack is empty")
    }

    element := stack.elements[stack.size-1]
    stack.elements = stack.elements[:stack.size-1]
    stack.size--

    return element, nil
}

func main() {
    stack := Stack{}

    stack.Push(1)
    stack.Push(2)
    stack.Push(3)

    for i := 0; i < 3; i++ {
        element, _ := stack.Pop()
        fmt.Println(element)
    }
}
Salin selepas log masuk

Dalam contoh ini, kami menggunakan kaedah Push dan Pop yang dilaksanakan di atas. Kaedah Push menambah elemen 1, 2, 3 pada tindanan, manakala kaedah Pop memaparkannya dan mencetaknya ke konsol.

Ringkasan:

Golang ialah bahasa pengaturcaraan yang cekap yang juga mempunyai prestasi cemerlang dalam pelaksanaan struktur data Antaranya, tindanan ialah struktur data yang amat penting untuk dipertimbangkan. Melalui artikel ini, kami telah mempelajari dan melaksanakan susunan Golang yang mudah, saya harap ia dapat membantu kerja pengaturcaraan anda.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan timbunan menggunakan 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