使用golang实现栈(stack)

2021/8/22 6:37:43

本文主要是介绍使用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)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程