1 Star 0 Fork 0

y18618233925 / gutils

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
stack.go 1.80 KB
一键复制 编辑 原始数据 按行查看 历史
phoebus 提交于 2024-04-28 10:53 . init
package utils
import (
"errors"
"fmt"
)
type Element interface{}
type Stack struct {
elements []Element
top int // 栈顶指针
cap int // 容量
}
// 初始化栈
func NewStack(cap int) *Stack {
// elements := make([]Element, cap)
elements := []Element{}
return &Stack{
elements: elements,
top: 0,
cap: cap,
}
}
// Push
func (stack *Stack) Push(element Element) (err error) {
// top == cap时,栈满
if stack.top >= stack.cap {
return errors.New("the stack is full")
}
// stack.elements[stack.top] = element
stack.elements = append(stack.elements, element)
stack.top++
return nil
}
func (stack *Stack) Top() Element {
// fmt.Println(stack.top)
// for i := 0; i < stack.top; i++ {
// fmt.Println(stack.elements[i])
// }
if stack.top <= 0 {
fmt.Println("XXXXXXXXX")
return nil
}
return stack.elements[stack.top-1]
}
// Pop
func (stack *Stack) Pop() (ele Element, err error) {
// top == 0时,栈空
if stack.top <= 0 {
return nil, errors.New("the stack is empty")
}
ele = stack.elements[stack.top-1]
// 在栈中清除当前元素
stack.elements = stack.elements[:stack.top-1]
// stack.elements = append(stack.elements, stack.elements[:stack.top], stack.elements[stack.top+1:])
stack.top--
return ele, nil
}
// Peek
func (stack *Stack) Peek() (ele Element, err error) {
if stack.top <= 0 {
return nil, errors.New("the stack is empty")
}
ele = stack.elements[stack.top-1]
return ele, nil
}
func (stack *Stack) Empty() bool {
return stack.top == 0
}
// Len
func (stack *Stack) Len() int {
return stack.top
}
// Cap
func (stack *Stack) Cap() int {
return stack.cap
}
// Clear
func (stack *Stack) Clear() {
if stack.top <= 0 {
return
}
// 重新分配一个空切片
// stack.elements = stack.elements[:0]
stack.elements = []Element{}
stack.top = 0
}
Go
1
https://gitee.com/y18618233925/gutils.git
git@gitee.com:y18618233925/gutils.git
y18618233925
gutils
gutils
v0.0.3

搜索帮助

53164aa7 5694891 3bd8fe86 5694891