婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Go實(shí)現(xiàn)雙向鏈表的示例代碼

Go實(shí)現(xiàn)雙向鏈表的示例代碼

熱門標(biāo)簽:浙江高速公路地圖標(biāo)注 廣州呼叫中心外呼系統(tǒng) 學(xué)海導(dǎo)航地圖標(biāo)注 地圖標(biāo)注的汽車標(biāo) 江西轉(zhuǎn)化率高的羿智云外呼系統(tǒng) 南通如皋申請開通400電話 西部云谷一期地圖標(biāo)注 高德地圖標(biāo)注口訣 中國地圖標(biāo)注省會高清

本文介紹什么是鏈表,常見的鏈表有哪些,然后介紹鏈表這種數(shù)據(jù)結(jié)構(gòu)會在哪些地方可以用到,以及 Redis 隊(duì)列是底層的實(shí)現(xiàn),通過一個(gè)小實(shí)例來演示 Redis 隊(duì)列有哪些功能,最后通過 Go 實(shí)現(xiàn)一個(gè)雙向鏈表。

目錄

1、鏈表

  • 1.1 說明
  • 1.2 單向鏈表
  • 1.3 循環(huán)鏈表
  • 1.4 雙向鏈表

2、redis隊(duì)列

  • 2.1 說明
  • 2.2 應(yīng)用場景
  • 2.3 演示

3、Go雙向鏈表

  • 3.1 說明
  • 3.2 實(shí)現(xiàn)

4、總結(jié)

5、參考文獻(xiàn)

  • 1、鏈表
  • 1.1 說明

鏈表(Linked list)是一種常見的基礎(chǔ)數(shù)據(jù)結(jié)構(gòu),是一種線性表,但是并不會按線性的順序存儲數(shù)據(jù),而是在每一個(gè)節(jié)點(diǎn)里存到下一個(gè)節(jié)點(diǎn)的指針(Pointer)。由于不必須按順序存儲,鏈表在插入的時(shí)候可以達(dá)到O(1)的復(fù)雜度,比另一種線性表順序表快得多,但是查找一個(gè)節(jié)點(diǎn)或者訪問特定編號的節(jié)點(diǎn)則需要O(n)的時(shí)間,而順序表相應(yīng)的時(shí)間復(fù)雜度分別是O(logn)和O(1)。

鏈表有很多種不同的類型:單向鏈表,雙向鏈表以及循環(huán)鏈表。

優(yōu)勢:

可以克服數(shù)組鏈表需要預(yù)先知道數(shù)據(jù)大小的缺點(diǎn),鏈表結(jié)構(gòu)可以充分利用計(jì)算機(jī)內(nèi)存空間,實(shí)現(xiàn)靈活的內(nèi)存動態(tài)管理。鏈表允許插入和移除表上任意位置上的節(jié)點(diǎn)。

劣勢:

由于鏈表增加了節(jié)點(diǎn)指針,空間開銷比較大。鏈表一般查找數(shù)據(jù)的時(shí)候需要從第一個(gè)節(jié)點(diǎn)開始每次訪問下一個(gè)節(jié)點(diǎn),直到訪問到需要的位置,查找數(shù)據(jù)比較慢。

用途:

常用于組織檢索較少,而刪除、添加、遍歷較多的數(shù)據(jù)。

如:文件系統(tǒng)、LRU cache、Redis 列表、內(nèi)存管理等。

1.2 單向鏈表

鏈表中最簡單的一種是單向鏈表,

一個(gè)單向鏈表的節(jié)點(diǎn)被分成兩個(gè)部分。它包含兩個(gè)域,一個(gè)信息域和一個(gè)指針域。第一個(gè)部分保存或者顯示關(guān)于節(jié)點(diǎn)的信息,第二個(gè)部分存儲下一個(gè)節(jié)點(diǎn)的地址,而最后一個(gè)節(jié)點(diǎn)則指向一個(gè)空值。單向鏈表只可向一個(gè)方向遍歷。

單鏈表有一個(gè)頭節(jié)點(diǎn)head,指向鏈表在內(nèi)存的首地址。鏈表中的每一個(gè)節(jié)點(diǎn)的數(shù)據(jù)類型為結(jié)構(gòu)體類型,節(jié)點(diǎn)有兩個(gè)成員:整型成員(實(shí)際需要保存的數(shù)據(jù))和指向下一個(gè)結(jié)構(gòu)體類型節(jié)點(diǎn)的指針即下一個(gè)節(jié)點(diǎn)的地址(事實(shí)上,此單鏈表是用于存放整型數(shù)據(jù)的動態(tài)數(shù)組)。鏈表按此結(jié)構(gòu)對各節(jié)點(diǎn)的訪問需從鏈表的頭找起,后續(xù)節(jié)點(diǎn)的地址由當(dāng)前節(jié)點(diǎn)給出。無論在表中訪問哪個(gè)節(jié)點(diǎn),都需要從鏈表的頭開始,順序向后查找。鏈表的尾節(jié)點(diǎn)由于無后續(xù)節(jié)點(diǎn),其指針域?yàn)榭眨瑢懽鳛镹ULL。

1.3 循環(huán)鏈表

循環(huán)鏈表是與單向鏈表一樣,是一種鏈?zhǔn)降拇鎯Y(jié)構(gòu),所不同的是,循環(huán)鏈表的最后一個(gè)結(jié)點(diǎn)的指針是指向該循環(huán)鏈表的第一個(gè)結(jié)點(diǎn)或者表頭結(jié)點(diǎn),從而構(gòu)成一個(gè)環(huán)形的鏈。

循環(huán)鏈表的運(yùn)算與單鏈表的運(yùn)算基本一致。所不同的有以下幾點(diǎn):

1、在建立一個(gè)循環(huán)鏈表時(shí),必須使其最后一個(gè)結(jié)點(diǎn)的指針指向表頭結(jié)點(diǎn),而不是像單鏈表那樣置為NULL。

2、在判斷是否到表尾時(shí),是判斷該結(jié)點(diǎn)鏈域的值是否是表頭結(jié)點(diǎn),當(dāng)鏈域的值等于表頭指針時(shí),說明已到表尾。而非象單鏈表那樣判斷鏈域的值是否為NULL。

1.4 雙向鏈表

雙向鏈表其實(shí)是單鏈表的改進(jìn),當(dāng)我們對單鏈表進(jìn)行操作時(shí),有時(shí)你要對某個(gè)結(jié)點(diǎn)的直接前驅(qū)進(jìn)行操作時(shí),又必須從表頭開始查找。這是由單鏈表結(jié)點(diǎn)的結(jié)構(gòu)所限制的。因?yàn)閱捂湵砻總€(gè)結(jié)點(diǎn)只有一個(gè)存儲直接后繼結(jié)點(diǎn)地址的鏈域,那么能不能定義一個(gè)既有存儲直接后繼結(jié)點(diǎn)地址的鏈域,又有存儲直接前驅(qū)結(jié)點(diǎn)地址的鏈域的這樣一個(gè)雙鏈域結(jié)點(diǎn)結(jié)構(gòu)呢?這就是雙向鏈表。

在雙向鏈表中,結(jié)點(diǎn)除含有數(shù)據(jù)域外,還有兩個(gè)鏈域,一個(gè)存儲直接后繼結(jié)點(diǎn)地址,一般稱之為右鏈域(當(dāng)此“連接”為最后一個(gè)“連接”時(shí),指向空值或者空列表);一個(gè)存儲直接前驅(qū)結(jié)點(diǎn)地址,一般稱之為左鏈域(當(dāng)此“連接”為第一個(gè)“連接”時(shí),指向空值或者空列表)。

2、redis隊(duì)列

2.1 說明

Redis 列表是簡單的字符串列表,按照插入順序排序。你可以添加一個(gè)元素到列表的頭部(左邊)或者尾部(右邊)

Redis 列表使用兩種數(shù)據(jù)結(jié)構(gòu)作為底層實(shí)現(xiàn):雙端列表(linkedlist)、壓縮列表(ziplist)

通過配置文件中(list-max-ziplist-entries、list-max-ziplist-value)來選擇是哪種實(shí)現(xiàn)方式

在數(shù)據(jù)量比較少的時(shí)候,使用雙端鏈表和壓縮列表性能差異不大,但是使用壓縮列表更能節(jié)約內(nèi)存空間

redis 鏈表的實(shí)現(xiàn)源碼 redis src/adlist.h

2.2 應(yīng)用場景

消息隊(duì)列,秒殺項(xiàng)目

秒殺項(xiàng)目:

提前將需要的商品碼信息存入 Redis 隊(duì)列,在搶購的時(shí)候每個(gè)用戶都從 Redis 隊(duì)列中取商品碼,由于 Redis 是單線程的,同時(shí)只能有一個(gè)商品碼被取出,取到商品碼的用戶為購買成功,而且 Redis 性能比較高,能抗住較大的用戶壓力。

2.3 演示

如何通過 Redis 隊(duì)列中防止并發(fā)情況下商品超賣的情況。

假設(shè):

網(wǎng)站有三件商品需要賣,我們將數(shù)據(jù)存入 Redis 隊(duì)列中

1、 將三個(gè)商品碼(10001、10002、10003)存入 Redis 隊(duì)列中

# 存入商品
RPUSH commodity:queue 10001 10002 10003

2、 存入以后,查詢數(shù)據(jù)是否符合預(yù)期

# 查看全部元素
LRANGE commodity:queue 0 -1

# 查看隊(duì)列的長度
LLEN commodity:queue

3、 搶購開始,獲取商品碼,搶到商品碼的用戶則可以購買(由于 Redis 是單線程的,同一個(gè)商品碼只能被取一次

# 出隊(duì)
LPOP commodity:queue

這里了解到 Redis 列表是怎么使用的,下面就用 Go 語言實(shí)現(xiàn)一個(gè)雙向鏈表來實(shí)現(xiàn)這些功能。

3、Go雙向鏈表

3.1 說明

這里只是用 Go 語言實(shí)現(xiàn)一個(gè)雙向鏈表,實(shí)現(xiàn):查詢鏈表的長度、鏈表右端插入數(shù)據(jù)、左端取數(shù)據(jù)、取指定區(qū)間的節(jié)點(diǎn)等功能( 類似于 Redis 列表的中的 RPUSH、LRANGE、LPOP、LLEN功能 )。

3.2 實(shí)現(xiàn)

節(jié)點(diǎn)定義

雙向鏈表有兩個(gè)指針,分別指向前一個(gè)節(jié)點(diǎn)和后一個(gè)節(jié)點(diǎn)

鏈表表頭 prev 的指針為空,鏈表表尾 next 的指針為空

// 鏈表的一個(gè)節(jié)點(diǎn)
type ListNode struct {
  prev *ListNode // 前一個(gè)節(jié)點(diǎn)
  next *ListNode // 后一個(gè)節(jié)點(diǎn)
  value string  // 數(shù)據(jù)
}

// 創(chuàng)建一個(gè)節(jié)點(diǎn)
func NewListNode(value string) (listNode *ListNode) {
  listNode = ListNode{
    value: value,
  }

  return
}

// 當(dāng)前節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)
func (n *ListNode) Prev() (prev *ListNode) {
  prev = n.prev

  return
}

// 當(dāng)前節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)
func (n *ListNode) Next() (next *ListNode) {
  next = n.next

  return
}

// 獲取節(jié)點(diǎn)的值
func (n *ListNode) GetValue() (value string) {
  if n == nil {

    return
  }
  value = n.value

  return
}

定義一個(gè)鏈表

鏈表為了方便操作,定義一個(gè)結(jié)構(gòu)體,可以直接從表頭、表尾進(jìn)行訪問,定義了一個(gè)屬性 len ,直接可以返回鏈表的長度,直接查詢鏈表的長度就不用遍歷時(shí)間復(fù)雜度從 O(n) 到 O(1)。

// 鏈表
type List struct {
  head *ListNode // 表頭節(jié)點(diǎn)
  tail *ListNode // 表尾節(jié)點(diǎn)
  len int    // 鏈表的長度
}


// 創(chuàng)建一個(gè)空鏈表
func NewList() (list *List) {
  list = List{
  }
  return
}

// 返回鏈表頭節(jié)點(diǎn)
func (l *List) Head() (head *ListNode) {
  head = l.head

  return
}

// 返回鏈表尾節(jié)點(diǎn)
func (l *List) Tail() (tail *ListNode) {
  tail = l.tail

  return
}

// 返回鏈表長度
func (l *List) Len() (len int) {
  len = l.len

  return
}

在鏈表的右邊插入一個(gè)元素

// 在鏈表的右邊插入一個(gè)元素
func (l *List) RPush(value string) {

  node := NewListNode(value)

  // 鏈表未空的時(shí)候
  if l.Len() == 0 {
    l.head = node
    l.tail = node
  } else {
    tail := l.tail
    tail.next = node
    node.prev = tail

    l.tail = node
  }

  l.len = l.len + 1

  return
}

從鏈表左邊取出一個(gè)節(jié)點(diǎn)

// 從鏈表左邊取出一個(gè)節(jié)點(diǎn)
func (l *List) LPop() (node *ListNode) {

  // 數(shù)據(jù)為空
  if l.len == 0 {

    return
  }

  node = l.head

  if node.next == nil {
    // 鏈表未空
    l.head = nil
    l.tail = nil
  } else {
    l.head = node.next
  }
  l.len = l.len - 1

  return
}

通過索引查找節(jié)點(diǎn)

通過索引查找節(jié)點(diǎn),如果索引是負(fù)數(shù)則從表尾開始查找。

自然數(shù)和負(fù)數(shù)索引分別通過兩種方式查找節(jié)點(diǎn),找到指定索引或者是鏈表全部查找完則查找完成。

// 通過索引查找節(jié)點(diǎn)
// 查不到節(jié)點(diǎn)則返回空
func (l *List) Index(index int) (node *ListNode) {

  // 索引為負(fù)數(shù)則表尾開始查找
  if index  0 {
    index = (-index) - 1
    node = l.tail
    for true {
      // 未找到
      if node == nil {

        return
      }

      // 查到數(shù)據(jù)
      if index == 0 {

        return
      }

      node = node.prev
      index--
    }
  } else {
    node = l.head
    for ; index > 0  node != nil; index-- {
      node = node.next
    }
  }

  return
}

返回指定區(qū)間的元素

// 返回指定區(qū)間的元素
func (l *List) Range(start, stop int) (nodes []*ListNode) {
  nodes = make([]*ListNode, 0)

  // 轉(zhuǎn)為自然數(shù)
  if start  0 {
    start = l.len + start
    if start  0 {
      start = 0
    }
  }

  if stop  0 {
    stop = l.len + stop
    if stop  0 {
      stop = 0
    }
  }

  // 區(qū)間個(gè)數(shù)
  rangeLen := stop - start + 1
  if rangeLen  0 {

    return
  }

  startNode := l.Index(start)
  for i := 0; i  rangeLen; i++ {
    if startNode == nil {
      break
    }

    nodes = append(nodes, startNode)
    startNode = startNode.next
  }

  return
}

4、總結(jié)

到這里關(guān)于鏈表的使用已經(jīng)結(jié)束,介紹鏈表是有哪些(單向鏈表,雙向鏈表以及循環(huán)鏈表),也介紹了鏈表的應(yīng)用場景(Redis 列表使用的是鏈表作為底層實(shí)現(xiàn)),最后用 Go 實(shí)現(xiàn)了雙向鏈表,演示了鏈表在 Go 語言中是怎么使用的,大家可以在項(xiàng)目中更具實(shí)際的情況去使用。

5、參考文獻(xiàn)

維基百科 鏈表

github redis

項(xiàng)目地址:go 實(shí)現(xiàn)隊(duì)列

https://github.com/link1st/link1st/tree/master/linked

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 詳解go語言單鏈表及其常用方法的實(shí)現(xiàn)
  • python/golang 刪除鏈表中的元素
  • python/golang實(shí)現(xiàn)循環(huán)鏈表的示例代碼
  • golang雙鏈表的實(shí)現(xiàn)代碼示例
  • Go語言單鏈表實(shí)現(xiàn)方法
  • go實(shí)現(xiàn)反轉(zhuǎn)鏈表

標(biāo)簽:保定 吐魯番 曲靖 德宏 許昌 常州 貴州 東營

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Go實(shí)現(xiàn)雙向鏈表的示例代碼》,本文關(guān)鍵詞  實(shí)現(xiàn),雙向,鏈表,的,示例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Go實(shí)現(xiàn)雙向鏈表的示例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于Go實(shí)現(xiàn)雙向鏈表的示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产日韩欧美电影| 亚洲免费观看高清完整| 一区二区三区在线视频免费观看| 91社区在线播放| 免费不卡在线视频| 亚洲三级电影网站| 国产欧美日本一区二区三区| 欧美一区二区三区小说| 成人黄色免费短视频| 国产老妇另类xxxxx| 日韩av电影一区| 亚洲精品一二三四区| 色狠狠一区二区三区香蕉| 日韩欧美一区中文| 久久草av在线| 另类成人小视频在线| 亚洲一区在线视频| 另类小说视频一区二区| 91.成人天堂一区| 一色桃子久久精品亚洲| 91在线观看一区二区| 成人av午夜影院| 日韩影院免费视频| 国产欧美日韩不卡| 日韩午夜在线影院| 日本成人中文字幕在线视频| 欧美sm美女调教| 激情文学综合插| 欧美国产欧美亚州国产日韩mv天天看完整 | 日韩激情在线观看| 91精品在线麻豆| 精品一区二区三区在线播放| 精品av久久707| 久久久久久日产精品| 国产99久久久精品| 亚洲精品精品亚洲| 欧美一区二区三区免费| 激情五月婷婷综合| 亚洲色大成网站www久久九九| 欧美午夜精品久久久久久超碰| 亚洲国产精品麻豆| 欧美成人一区二区三区片免费| 国产综合色精品一区二区三区| 国产精品久久久爽爽爽麻豆色哟哟| 在线区一区二视频| 久久疯狂做爰流白浆xx| 国产欧美一区二区精品久导航| 91麻豆免费看片| 色综合色综合色综合| av中文字幕一区| 91国在线观看| 欧美一区在线视频| 亚洲欧美一区二区三区久本道91| 1000部国产精品成人观看| 久久er99精品| 欧美电影在线免费观看| 自拍偷拍欧美激情| 成人av综合一区| 国产亚洲成年网址在线观看| 亚洲一区二区视频在线观看| 国产成人a级片| 日韩欧美国产电影| 久久精品国产77777蜜臀| 欧美撒尿777hd撒尿| 欧美精品久久一区| 欧美剧情片在线观看| 国产在线不卡视频| 日本乱人伦aⅴ精品| 成人性生交大片免费看中文| 国产裸体歌舞团一区二区| 色综合天天狠狠| 午夜久久久久久电影| 亚洲伦理在线免费看| 麻豆精品一区二区三区| 亚洲欧美综合另类在线卡通| 日韩精品一区二区三区在线| 视频一区在线播放| 久久精品视频免费| 精品夜夜嗨av一区二区三区| 日韩欧美一区二区免费| 91福利资源站| 亚洲bdsm女犯bdsm网站| 中文字幕亚洲欧美在线不卡| 久久综合国产精品| 欧美一区二区精品| 欧美日韩三级视频| 在线观看不卡视频| 91日韩精品一区| 成人性生交大合| 国产高清无密码一区二区三区| 久久99精品久久久| 精彩视频一区二区三区| 乱一区二区av| 久久国产尿小便嘘嘘| 美腿丝袜在线亚洲一区| 美女一区二区三区| 免费久久精品视频| 伦理电影国产精品| 精品一区二区三区在线播放| 蜜臀av亚洲一区中文字幕| 蜜臀av一区二区在线免费观看| 日本亚洲三级在线| 六月丁香综合在线视频| 另类小说一区二区三区| 久久精品国产亚洲a| 精品一区二区三区在线视频| 国产精品综合一区二区三区| 国产麻豆视频一区| 99久久婷婷国产精品综合| 日本少妇一区二区| 亚洲欧美偷拍卡通变态| 国产亚洲1区2区3区| 精品久久久久久久人人人人传媒| 粗大黑人巨茎大战欧美成人| 在线不卡一区二区| 日韩精品国产精品| 亚洲色图视频网| 国产精品每日更新在线播放网址| 欧美日韩国产片| 欧美性xxxxxx少妇| 91年精品国产| 欧美性生活久久| a在线欧美一区| 欧美日韩一级黄| 成人黄色网址在线观看| 国产一区二区久久| 久久久蜜桃精品| 欧美日韩精品欧美日韩精品一 | 久久久精品国产免大香伊| 久久久精品免费观看| 国产精品国产a| 亚洲国产精品尤物yw在线观看| 丝袜诱惑制服诱惑色一区在线观看| 美洲天堂一区二卡三卡四卡视频| 亚洲国产精品久久久男人的天堂| 午夜私人影院久久久久| 亚洲成人精品一区二区| 久久蜜桃一区二区| 国产精品国产a| 国产精品自产自拍| 高清av一区二区| 欧美一级理论片| 国内精品伊人久久久久av一坑| 狠狠v欧美v日韩v亚洲ⅴ| www.欧美色图| 日韩一区二区麻豆国产| 欧美高清在线视频| 日韩电影在线免费观看| 成人av电影在线播放| 欧美一级欧美一级在线播放| 成人欧美一区二区三区1314| 美女视频免费一区| 色一区在线观看| 久久久综合网站| 日日夜夜免费精品| 99精品国产99久久久久久白柏| 日韩视频一区二区| 亚洲综合在线第一页| 国产99久久久精品| 日韩一区二区麻豆国产| 亚洲免费av在线| 国产高清亚洲一区| 欧美xxxx在线观看| 亚洲第一二三四区| 不卡电影一区二区三区| 欧美成人伊人久久综合网| 亚洲成a天堂v人片| 91国模大尺度私拍在线视频| 中文字幕精品一区二区精品绿巨人 | 91视频观看视频| www久久精品| 日韩中文字幕亚洲一区二区va在线 | 亚洲成人福利片| 成人黄色国产精品网站大全在线免费观看 | 国产在线精品一区二区不卡了 | 亚洲国产精品久久艾草纯爱 | 国产v日产∨综合v精品视频| 91麻豆精品国产综合久久久久久| 日韩二区三区四区| 91蜜桃视频在线| 亚洲免费观看高清完整版在线观看 | 色综合天天综合网国产成人综合天 | 色综合天天综合| 亚洲欧美日韩综合aⅴ视频| 99国产精品视频免费观看| 国产欧美久久久精品影院| 国产成人综合在线| 欧美视频完全免费看| 免费美女久久99| 久久久三级国产网站| 色综合亚洲欧洲| 亚洲成人av资源| 亚洲国产高清aⅴ视频| 日韩av一区二区在线影视| 亚洲少妇最新在线视频| 麻豆一区二区99久久久久| 国产成人免费av在线| 成人午夜在线视频| 国产精品免费视频观看| 国产91丝袜在线播放0|