内容简介:list包的ArrayList类main包的测试类程序输出如下,
list包的ArrayList类
package list
type ArrayList struct {
elements []interface{}
size int
}
func New(values ...interface{}) *ArrayList {
list := &ArrayList{}
list.elements = make([]interface{}, 10)
if len(values) > 0 {
list.Add(values...)
}
return list
}
func (list *ArrayList) Add(values ...interface{}) {
if list.size+len(values) >= len(list.elements)-1 {
newElements := make([]interface{}, list.size+len(values)+1)
copy(newElements, list.elements)
list.elements = newElements
}
for _, value := range values {
list.elements[list.size] = value
list.size++
}
}
func (list *ArrayList) Remove(index int) interface{} {
if index < 0 || index >= list.size {
return nil
}
curEle := list.elements[index]
list.elements[index] = nil
copy(list.elements[index:], list.elements[index+1:list.size])
list.size--
return curEle
}
func (list *ArrayList) Get(index int) interface{} {
if index < 0 || index >= list.size {
return nil
}
return list.elements[index]
}
func (list *ArrayList) IsEmpty() bool {
return list.size == 0
}
func (list *ArrayList) Size() int {
return list.size
}
func (list *ArrayList) Contains(value interface{}) bool {
for _, curValue := range list.elements {
if curValue == value {
return true
}
}
return false
}
main包的测试类
package main
import (
"arrlist/list"
"fmt"
)
func main() {
list := list.New()
list.Add(1, 2, 3, 4, 5)
i := 0
for i < list.Size() {
fmt.Println(list.Get(i))
i++
}
fmt.Println("Size of list:", list.Size())
fmt.Println(list.Contains(4))
}
程序输出如下,
image.png
以上所述就是小编给大家介绍的《Golang实现简单的ArrayList》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- php如何实现session,自己实现session,laravel如何实现session
- AOP如何实现及实现原理
- webpack 实现 HMR 及其实现原理
- Docker实现原理之 - OverlayFS实现原理
- 为什么实现 .NET 的 ICollection 集合时需要实现 SyncRoot 属性?如何正确实现这个属性?
- 自己实现集合框架(十):顺序栈的实现
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法分析导论
(美)Robert Sedgewick、(法)Philippe Flajolet / 冯舜玺、李学武、裴伟东、等其他 / 机械工业出版社 / 2006-4 / 38.00元
本书阐述了用于算法数学分析的主要方法,所涉及的材料来自经典数学课题,包括离散数学、初等实分析、组合数学,以及来自经典的计算机科学课题,包括算法和数据结构,本书内容集中覆盖基础、重要和有趣的算法,前面侧重数学,后面集中讨论算法分析的应用,重点的算法分的的数学方法。每章包含大量习题以及参考文献,使读者可以更深入地理解书中的内容。 本书适合作为高等院校数学、计算机科学以及相关专业的本科生和研究生的......一起来看看 《算法分析导论》 这本书的介绍吧!