Go语言实战案例-自定义栈结构

以下是《Go语言100个实战案例》中的 数据结构与算法篇 - 案例23:自定义栈结构 的完整内容,帮助初学者通过自定义结构体来实现栈的数据结构。

🎯 案例目标

实现一个自定义的栈结构,并提供常见的栈操作:压栈(Push)、弹栈(Pop)、查看栈顶元素(Peek)和判断栈是否为空(IsEmpty)。


🧩 应用场景

  • • 栈结构是计算机科学中常用的数据结构,用于处理函数调用、括号匹配、表达式求值等问题。
  • • 在 Go 语言中,可以通过结构体来定义栈,并实现各种栈操作。
  • • 初学者可以通过此案例深入理解栈的工作原理,并练习使用结构体和切片(slice)来实现栈。

🧠 涉及知识点

  • • 使用结构体定义栈(Stack)
  • • 栈操作的基本方法(Push、Pop、Peek、IsEmpty)
  • • 使用 Go 的切片(slice)动态调整栈大小

💻 示例代码:自定义栈结构

go 复制代码
package main

import "fmt"

// 定义栈结构体
type Stack struct {
    elements []interface{} // 用切片存储栈元素
}

// 创建一个新的栈
func NewStack() *Stack {
    return &Stack{}
}

// 判断栈是否为空
func (s *Stack) IsEmpty() bool {
    return len(s.elements) == 0
}

// 获取栈的大小
func (s *Stack) Size() int {
    return len(s.elements)
}

// 压栈操作
func (s *Stack) Push(item interface{}) {
    s.elements = append(s.elements, item)
}

// 弹栈操作
func (s *Stack) Pop() (interface{}, bool) {
    if s.IsEmpty() {
        return nil, false // 栈为空,返回错误
    }
    // 获取栈顶元素并移除
    topIndex := len(s.elements) - 1
    item := s.elements[topIndex]
    s.elements = s.elements[:topIndex]
    return item, true
}

// 查看栈顶元素
func (s *Stack) Peek() (interface{}, bool) {
    if s.IsEmpty() {
        return nil, false // 栈为空,返回错误
    }
    return s.elements[len(s.elements)-1], true
}

func main() {
    stack := NewStack() // 创建一个栈

    // 测试压栈操作
    stack.Push(10)
    stack.Push(20)
    stack.Push(30)
    fmt.Println("栈的大小:", stack.Size()) // 输出栈的大小

    // 查看栈顶元素
    top, _ := stack.Peek()
    fmt.Println("栈顶元素:", top)

    // 测试弹栈操作
    item, _ := stack.Pop()
    fmt.Println("弹出的元素:", item)
    fmt.Println("弹栈后的栈的大小:", stack.Size())

    // 再次查看栈顶元素
    top, _ = stack.Peek()
    fmt.Println("新的栈顶元素:", top)

    // 弹栈直到栈空
    for !stack.IsEmpty() {
        item, _ = stack.Pop()
        fmt.Println("弹出的元素:", item)
    }
}

🛠 技术说明

功能 使用方法
定义栈结构体 type Stack struct { elements []interface{} }
栈操作方法 PushPopPeekIsEmpty
切片操作 append、切片截取 s.elements[:topIndex]
空值检查 IsEmpty 判断栈是否为空
多种数据类型存储 使用 interface{} 存储任何类型的数据

📤 示例运行

makefile 复制代码
栈的大小: 3
栈顶元素: 30
弹出的元素: 30
弹栈后的栈的大小: 2
新的栈顶元素: 20
弹出的元素: 20
弹出的元素: 10

🧪 拓展练习

  • 栈的扩展 :实现一个支持栈的最大值(或最小值)跟踪功能,即每次 Push 时,栈顶同时保存当前最大(或最小)值。
  • 栈的应用
    • • 用栈来实现括号匹配检查,确保每个 ( 都有相应的 )
    • • 用栈解决计算机表达式求值问题(如逆波兰表达式计算)。
  • 线程安全 :考虑使用 Go 的并发机制(如 sync.Mutex)来实现线程安全的栈操作,适用于多线程环境。

✅ 小结

通过本案例,你实现了一个自定义栈结构,并掌握了 mapinterface{} 和 Go 语言切片等核心概念。栈是一个非常重要的数据结构,在编程中有着广泛的应用,尤其是在解析、计算和回溯等场景中。

相关推荐
超浪的晨31 分钟前
Java 单元测试详解:从入门到实战,彻底掌握 JUnit 5 + Mockito + Spring Boot 测试技巧
java·开发语言·后端·学习·单元测试·个人开发
艺杯羹3 小时前
MyBatis 之缓存机制核心解析
java·后端·spring·mybatis
Brookty3 小时前
【Java学习】匿名内部类的向外访问机制
java·开发语言·后端·学习
程序员爱钓鱼3 小时前
Go语言实战案例-快速排序实现
后端·google·go
程序员爱钓鱼3 小时前
Go语言实战案例-链表的实现与遍历
后端·google·go
超浪的晨10 小时前
Java 实现 B/S 架构详解:从基础到实战,彻底掌握浏览器/服务器编程
java·开发语言·后端·学习·个人开发
追逐时光者11 小时前
一款超级经典复古的 Windows 9x 主题风格 Avalonia UI 控件库,满满的回忆杀!
后端·.net
Python涛哥12 小时前
go语言基础教程:【1】基础语法:变量
开发语言·后端·golang
我命由我1234512 小时前
PostgreSQL 保留关键字冲突问题:语法错误 在 “user“ 或附近的 LINE 1: CREATE TABLE user
数据库·后端·sql·mysql·postgresql·问题·数据库系统
LUCIAZZZ13 小时前
final修饰符不可变的底层
java·开发语言·spring boot·后端·spring·操作系统