Golang 实现栈(Stack)数据结构

Golang 实现栈(Stack)数据结构

废话不说上代码:

package main
 
import "fmt"

type Element interface{}//可存入任何类型

type Stack struct {
    list []Element
}
 
//初始化栈
func NewStack()*Stack {
    return &Stack{list: make([]Element,0)}
}
 
func (s*Stack)Len()int  {
    return len(s.list)
}
 
//判断栈是否空
func (s*Stack)IsEmpty()bool  {
    return len(s.list) == 0
}
 
//入栈
func (s *Stack)Push(x interface{})  {
    s.list = append(s.list, x)
}
 
//连续传入
func (s *Stack)PushList(x []Element)  {
    s.list = append(s.list, x...)
}
 
//出栈
func (s*Stack)Pop() Element{
    if len(s.list)<=0{
        //fmt.Println("Stack is Empty")
        return nil
    }else {
        ret:=s.list[len(s.list)-1]
        s.list = s.list[:len(s.list)-1]
        return ret
    }
}
 
//返回栈顶元素,空栈返nil
func (s*Stack)Top() Element {
    if s.IsEmpty()==true{
        //fmt.Println("Stack is Empty")
        return nil
    }else{
        return s.list[len(s.list)-1]
    }
}
 
//清空栈
func (s*Stack)Clear(){
    if len(s.list)==0{
        return
    }
    for i:=0;i<s.Len();i++{
        s.list[i]=nil
    }
    s.list = make([]Element,0)
}
 
//打印测试
func (s *Stack)Show()  {
    _len:=len(s.list)
    for i:=0;i!=_len;i++{
        fmt.Println(s.Pop()) //这个注意:show会清空栈
    }
}
 
func main()  { //测试
    stack:=NewStack()
    stack.Push(1)
    stack.Push(2)
    stack.Push(3)
    stack.Pop()
    stack.PushList([]Element{4,5,6,7})//list方式放入1
    fmt.Println("Stack len is ",stack.Len())
    fmt.Println("Top is",stack.Top())//栈顶元素
    stack.Show()//show之后数据已经清空
}

有些借鉴网上,主要是网上零零散散的,有的甚至不能用,但我这个亲测可用;
源码进行了一些必要的优化,冗余部分都被我改了.

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dtsroy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值