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)
}