主页 > 知识库 > go语言实现顺序存储的栈

go语言实现顺序存储的栈

热门标签:外呼系统如何接收服务密码 工商信用卡外呼系统教程 滁州自建外呼系统 智能营销软件 外呼系统多少钱一年 经常接到推销电话机器人的电话 客服级电销机器人 旅游厕所如何电子地图标注 海外照相馆地图标注入驻

本文实例讲述了go语言实现顺序存储的栈。分享给大家供大家参考。具体如下:

1. sequence.go代码如下:

复制代码 代码如下:
////////
// 顺序存储的栈
////////
package sequence
const MAXSIZE = 20
type Stack struct {
    Data [MAXSIZE]int //存储栈元素
    Top  int          //指向栈顶,总是指向顶部元素,空时为-1
}
//压栈
//d:栈元素
func (s *Stack) Push(d int) bool {
    if s.Top+1 > MAXSIZE {
        return false
    }
    s.Data[s.Top+1] = d
    s.Top++
    return true
}
//弹栈
func (s *Stack) Pop() int {
    if s.Top == -1 {
        return 0
    }
    s.Data[s.Top] = 0
    d := s.Data[s.Top]
    s.Top--
    return d
}
//取栈的容量
func (s *Stack) GetVol() int {
    return len(s.Data)
}
//取栈的长度
func (s *Stack) GetLength() int {
    c := s.Top + 1
    return c
}

2. main.go代码如下:
复制代码 代码如下:
package main
import (
    "fmt"
    "stack/sequence"
)
func main() {
    //初始化一个栈
    var s sequence.Stack
    s.Top = -1
 
    //压入10个元素
    for i := 1; i = 10; i++ {
        s.Push(i)
    }
    fmt.Println(s)
    fmt.Println(s.GetVol())    //容量
    fmt.Println(s.GetLength()) //长度
 
    //弹出一个元素
    s.Pop()
    s.Pop()
    fmt.Println(s)
    fmt.Println(s.GetVol())    //容量
    fmt.Println(s.GetLength()) //长度
}

希望本文所述对大家的Go语言程序设计有所帮助。

您可能感兴趣的文章:
  • Go语言单链表实现方法
  • Go语言基础知识总结(语法、变量、数值类型、表达式、控制结构等)
  • go语言实现一个最简单的http文件服务器实例
  • go语言中时间戳格式化的方法
  • go语言检测文件是否存在的方法
  • go语言读取csv文件并输出的方法
  • Go语言对字符串进行MD5加密的方法
  • Go语言实现顺序存储的线性表实例

标签:深圳 运城 湘潭 本溪 喀什 楚雄 晋城 九江

巨人网络通讯声明:本文标题《go语言实现顺序存储的栈》,本文关键词  语言,实现,顺序,存储,的,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《go语言实现顺序存储的栈》相关的同类信息!
  • 本页收集关于go语言实现顺序存储的栈的相关信息资讯供网民参考!
  • 推荐文章