Go Code#
Stack#
var ErrEmptyStack = errors.New("pop from empty stack")
type Stack[T any] struct {
items []T
}
func (s *Stack[T]) Push(v T) {
s.items = append(s.items, v)
}
func (s *Stack[T]) Pop() (T, error) {
var zero T
if len(s.items) == 0 {
return zero, ErrEmptyStack
}
n := len(s.items) - 1
v := s.items[n]
s.items[n] = zero // remove previous val for GC
s.items = s.items[:n]
return v, nil
}
func (s *Stack[T]) Peek() (T, error) {
if len(s.items) == 0 {
var zero T
return zero, ErrEmptyStack
}
return s.items[len(s.items) - 1], nil
}
func (s *Stack[T]) Len() int {
return len(s.items)
}