您好,登錄后才能下訂單哦!
初始化一個列表,返回類型為一個list對象
a := list.New() # 在函數內部
a = list.New()
輸出:
&{{0xc00006a300 0xc00006a300 <nil> <nil>} 0}
返回鏈表的最后一個元素,返回類型元列表中的元素。
x := a.Back()
fmt.Println(strings.Repeat("-----------", 10))
fmt.Println(x)
&{0xc00006a300 0xc00006a330 0xc00006a300 b}
返回鏈表的第一個元素,返回類型元列表中的元素。
x := a.Front()
fmt.Println(strings.Repeat("-----------", 10))
fmt.Println(x)
&{0xc00006a360 0xc00006a300 0xc00006a300 a}
初始化此鏈表,將元素全部清空
m := a.Init()
fmt.Println(m)
輸出:
&{{0xc00006a300 0xc00006a300 <nil> <nil>} 0}
InsertAfter在mark之后立即插入一個值為v的新元素e并返回e。如果mark不是l的元素,則不修改列表。商標不得為零。
b := a.PushBack("b")
fmt.Println(a.InsertAfter("mm", b))
fmt.Println(a)
&{0xc000068300 0xc000068360 0xc000068300 mm}
&{{0xc000068300 0xc000068480 <nil> <nil>} 1}
b := a.PushBack("b")
fmt.Println(a.InsertBefore("mm", b))
fmt.Println(a)
&{0xc000068300 0xc000068360 0xc000068300 mm}
&{{0xc000068300 0xc000068480 <nil> <nil>} 1}
返回鏈表的長度,返回值類型為×××
fmt.Println(a.Len())
1
MoveAfter將標記后的元素e移動到新位置。如果e或mark不是l或e == mark的元素,則不修改列表。元素和標記不得為零。
MoveBefore將元素e移動到標記前的新位置。如果e或mark不是l或e == mark的元素,則不修改列表。元素和標記不得為零。
MoveToBack將元素e移動到列表l的后面。如果e不是l的元素,則不修改列表。元素不能為零。
MoveToFront將元素e移動到列表l的前面。如果e不是l的元素,則不修改列表。元素不能為零。
PushBack在列表l的后面插入一個值為v的新元素e并返回e。
a.PushBack("a")
b := a.PushBack("b")
PushBackList在列表l的后面插入另一個列表的副本。列表l和其他可以是相同的。他們一定不能為零。
PushFront在列表l的前面插入一個值為v的新元素e并返回e。
PushFrontList在列表l的前面插入另一個列表的副本。列表l和其他可以是相同的。他們一定不能為零。
如果e是列表l的元素,則刪除從l中刪除e。它返回元素值e.Value。元素不能為零。
Next返回下一個list元素或nil
Prev返回前一個列表元素或nil。
x := a.Front()
fmt.Println(x.Value)
for e := a.Front(); e != nil; e = e.Next() {
fmt.Println(e.Value)
}
輸出:
3
a
b
mm
鏈表適合于頻繁存取的數據結構中。
切片適合于頻繁查詢的數據結構中。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。