Go 语言数据结构

1、栈

  1、linkedliststack

        地址:"github.com/emirpasic/gods/stacks/linkedliststack"

  

复制代码
import (
    "fmt"
    "github.com/emirpasic/gods/stacks/linkedliststack"
)

func main() {
    // 1. 构造一个空栈
    stack := linkedliststack.New()

    // 2. 判断是否是一个空栈
    if isEmpty := stack.Empty(); isEmpty {
        fmt.Printf("一个空栈\n")
    }

    // 3. Push 插入数据
    stack.Push(1)
    stack.Push(2)
    stack.Push(3)

    // 4. Size 元素的个数
    fmt.Println("元素的个数是:", stack.Size())

    // 5、遍历
    values := stack.Values()
    for k, v := range values {
        fmt.Printf("第%d个元素, 值为%d\n", k, v.(int))
    }

    // 6、获取栈顶的元素
    if value, ok := stack.Peek(); ok {
        fmt.Println("栈顶元素为: ", value)
    }

    // 7、弹出
    //stack.Pop()
    //fmt.Println("元素的个数是:", stack.Size())

    // 8、清空
    //stack.Clear()
    //fmt.Println("元素的个数是:", stack.Size())

    // 9、通过迭代器遍历
    iterator := stack.Iterator()
    for iterator.Next() {
        index := iterator.Index()
        value := iterator.Value()
        fmt.Println("index = ", index, " ,value = ", value)
    }
}
复制代码

 

 

  

  

 

posted @   dogRuning  阅读(26)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
点击右上角即可分享
微信分享提示