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 语言切片等核心概念。栈是一个非常重要的数据结构,在编程中有着广泛的应用,尤其是在解析、计算和回溯等场景中。

相关推荐
uzong16 分钟前
技术故障复盘模版
后端
GetcharZp44 分钟前
基于 Dify + 通义千问的多模态大模型 搭建发票识别 Agent
后端·llm·agent
桦说编程1 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
IT毕设实战小研1 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
wyiyiyi2 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
阿华的代码王国3 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
Jimmy3 小时前
AI 代理是什么,其有助于我们实现更智能编程
前端·后端·ai编程
AntBlack3 小时前
不当韭菜V1.1 :增强能力 ,辅助构建自己的交易规则
后端·python·pyqt
bobz9654 小时前
pip install 已经不再安全
后端
寻月隐君4 小时前
硬核实战:从零到一,用 Rust 和 Axum 构建高性能聊天服务后端
后端·rust·github