本文主要是介绍使用golang实现栈(stack),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
package main
import (
"fmt"
"errors"
)
type Stack []int
// 入栈
func (s *Stack) push(a int) {
*s = append(*s, a)
}
// 出栈
func (s *Stack) pop() (int, error) {
if (len(*s) == 0) {
return 0, errors.New("Empty Stack")
}
a := *s
defer func() {
*s = a[:len(a) - 1]
}()
return a[len(a) - 1], nil
}
func main() {
// 数据初始化化
var s Stack = []int{12}
s.push(10)
fmt.Printf("入栈后的 Stack : %v\n", s)
a, err := s.pop()
fmt.Printf("出栈的数据:%v , 目前的 Stack : %v, Error: %v\n", a, s, err)
}
这篇关于使用golang实现栈(stack)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!