码迷,mamicode.com
首页 > 其他好文 > 详细

用go实现的一个堆得数据结构

时间:2018-05-09 20:58:09      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:print   pack   代码   new   ack   main   code   func   ola   

用golang实现的堆,主要提供了两个方法,push和pop及堆的大小,代码如下:

package main

import (
    "errors"
    "fmt"
)

type Stack []interface{}

func (s *Stack) Push(x interface{}) {
    *s = append(*s, x)
}

func (s *Stack) Pop() (interface{}, error) {
    if len(*s) == 0 {
        return nil, errors.New("slice为空!")
    }
    result := (*s)[len(*s)-1]
    *s = (*s)[:len(*s)-1]
    return result, nil
}

func (s *Stack) Len() int {
    return len(*s)
}

func main() {
    s := new(Stack)
    s.Push(1)
    s.Push(2)
    fmt.Println(s, s.Len())
    s.Pop()
    fmt.Println(s, s.Len())
}

用go实现的一个堆得数据结构

标签:print   pack   代码   new   ack   main   code   func   ola   

原文地址:https://www.cnblogs.com/ontheway1024/p/9016150.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!