golang list用法笔记

2020-06-08  本文已影响0人  guonaihong

依赖

import (
        "container/list"
        "fmt"
)

遍历

go的list也是用双向循环链表实现的,在尾部追加用PushBack()

// 声明链表
l := list.New()

// 数据添加到尾部
l.PushBack(4)
l.PushBack(5)
l.PushBack(6)

// 遍历
for e := l.Front(); e != nil; e = e.Next() {
     fmt.Printf("%v\n", e.Value)
}

删除元素

删除使用list.Remove(element)

 l := list.New()
 l.PushBack(4)
 six := l.PushBack(6)
 l.Remove(six) // 删除6这个节点

合并两个链表(list1)

这里面使用list1.PushBackList(list2)

l := list.New()
l.PushBack(1)
l.PushBack(2)
l.PushBack(3)

l2 := list.New()
l2.PushBack(4)
l2.PushBack(5)
l2.PushBack(6)

l2.PushBackList(l2)
fmt.Printf("merge after l================\n")
for e := l.Front(); e != nil; e = e.Next() {
        fmt.Printf("%d\n", e.Value.(int))
}

fmt.Printf("merge after l2================\n")
for e := l2.Front(); e != nil; e = e.Next() {
        fmt.Printf("%d\n", e.Value.(int))
}

一边遍历一边删除

要注意的是,先缓存下个节点指针。才能删除。

fmt.Printf("delete and range \n")

l := list.New()
l.PushBack(1)
l.PushBack(2)
l.PushBack(3)

for e := l.Front(); e != nil; {
        next := e.Next()
        l.Remove(e)
        e = next
}

上一篇 下一篇

猜你喜欢

热点阅读