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

主頁 > 知識庫 > golang雙鏈表的實現代碼示例

golang雙鏈表的實現代碼示例

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

雙鏈表的實現

基本概念

每一個節點都存儲上一個和下一個節點的指針

實現思路

創建一個節點結構體

  • 每個節點都有上節點指針與下節點指針
  • 每個節點都有一個key => value

創建一個鏈表結構體

  • 鏈表容量大小屬性
  • 鏈表大小屬性
  • 鏈表鎖, 實現并發安全
  • 鏈表頭節點
  • 鏈表尾節點

實現鏈表操作方法

  • 添加頭部節點操作AppendHead
  • 添加尾部節點操作AppendTail
  • 追加尾部節點操作Append
  • 插入任意節點操作Insert
  • 刪除任意節點操作Remove
  • 刪除頭部節點操作RemoveHead
  • 刪除尾部節點操作RemoveTail
  • 獲取指定位置的節點Get
  • 搜索任意節點Search
  • 獲取鏈表大小GetSize
  • 打印所有節點操作Print
  • 反轉所有節點操作Reverse

總結

  1. 學好算法是一個不斷積累的過程
  2. 學習時還需做到知行合一
  3. 實現時需要多做用例測試.

代碼解析

定義節點的結構體

type DoubleNode struct {
  Key  int     //鍵
  Value interface{} //值
  Prev *DoubleNode //上一個節點指針
  Next *DoubleNode //下一個節點指針
  Freq int     //頻率次數.為了給LFU使用的
}

定義一個雙鏈表的結構體

//定義一個雙鏈表的結構
type DoubleList struct {
  lock   *sync.RWMutex //鎖
  Capacity uint     //最大容量
  Size   uint     //當前容量
  Head   *DoubleNode  //頭節點
  Tail   *DoubleNode  //尾部節點
}

初使雙鏈表

//初使雙鏈表
func New(capacity uint) *DoubleList {
  list := new(DoubleList)
  list.Capacity = capacity
  list.lock = new(sync.RWMutex)
  list.Size = 0
  list.Head = nil
  list.Tail = nil
  return list
}

添加頭部節點

實現思路

  1. 先判斷容量大小
  2. 判斷頭部是否為空,
    1. 如果為空則添加新節點
    2. 如果不為空則更改現有的節點,并添加上
func (list *DoubleList) AddHead(node *DoubleNode) bool {
  //判斷容量是否為0
  if list.Capacity == 0 {
    return false
  }
  list.lock.Lock()
  defer list.lock.Unlock()
  //判斷頭部節點是否為nil
  if list.Head == nil {
    list.Head = node
    list.Tail = node
  } else { //存在頭部節點
    list.Head.Prev = node //將舊頭部節點上一個節點指向新節點
    node.Next = list.Head //新頭部節點下一個節點指向舊頭部節點
    list.Head = node   //設置新的頭部節點
    list.Head.Prev = nil //將新的頭部節點上一個節點設置NIL
  }
  list.Size++
  return true
}

添加尾部元素

實現思路

  • 先判斷容量大小
  • 判斷尾部是否為空,
    • 如果為空則添加新節點
    • 如果不為空則更改現有的節點,并添加上
func (list *DoubleList) AddTail(node *DoubleNode) bool {
  //判斷是否有容量,
  if list.Capacity == 0 {
    return false
  }
  list.lock.Lock()
  defer list.lock.Unlock()
  //判斷尾部是否為空
  if list.Tail == nil {
    list.Tail = node
    list.Head = node
  } else {
    //舊的尾部下個節點指向新節點
    list.Tail.Next = node
    //追加新節點時,先將node的上節點指向舊的尾部節點
    node.Prev = list.Tail
    //設置新的尾部節點
    list.Tail = node
    //新的尾部下個節點設置為空
    list.Tail.Next = nil
  }
  //雙鏈表大小+1
  list.Size++
  return true
}

添加任意位置元素

實現思路

  • 判斷容量大小
  • 判斷鏈表大小
  • 第一種: 如果插入的位置大于當前長度則尾部添加
  • 第二種: 如果插入的位置等于0則,頭部添加
  • 第三種: 中間插入節點
    • 先取出要插入位置的節點,假調為C節點
    • 介于A, C之間, 插入一個B節點
    • A的下節點應該是B, 即C的上節點的下節點是B
    • B的上節點是C的上節點
    • B的下節點是C
//添加任意位置元素
func (list *DoubleList) Insert(index uint, node *DoubleNode) bool {
  //容量滿了
  if list.Size == list.Capacity {
    return false
  }
  //如果沒有節點
  if list.Size == 0 {
    return list.Append(node)
  }
  //如果插入的位置大于當前長度則尾部添加
  if index > list.Size {
    return list.AddTail(node)
  }
  //如果插入的位置等于0則,頭部添加
  if index == 0 {
    return list.AddHead(node)
  }
  //取出要插入位置的節點
  nextNode := list.Get(index)
  list.lock.Lock()
  defer list.lock.Unlock()
  //中間插入:
  //假設已有A, C節點, 現在要插入B節點
  // nextNode即是C節點,
  //A的下節點應該是B, 即C的上節點的下節點是B
  nextNode.Prev.Next = node
  //B的上節點是C的上節點
  node.Prev = nextNode.Prev
  //B的下節點是C
  node.Next = nextNode
  //C的上節點是B
  nextNode.Prev = node
  list.Size++
  return true
}

刪除頭部節點

實現思路

  1. 判斷頭部是否為空
  2. 將頭部節點取出來
  3. 判斷頭部是否有下一個節點
    1. 沒有下一個節點,則說明只有一個節點, 刪除本身,無須移動指針位置
    2. 如果有下一個節點,則頭部下一個節點即是頭部節點.
//刪除頭部節點
func (list *DoubleList) RemoveHead() *DoubleNode {
  //判斷頭部節點是否為空
  if list.Head == nil {
    return nil
  }
  list.lock.Lock()
  defer list.lock.Unlock()
  //將頭部節點取出來
  node := list.Head
  //判斷頭部是否有下一個節點
  if node.Next != nil {
    list.Head = node.Next
    list.Head.Prev = nil
  } else { //如果沒有下一個節點, 說明只有一個節點
    list.Head, list.Tail = nil, nil
  }
  list.Size--
  return node
}

刪除尾部節點

實現思路

  1. 判斷尾部節點是否為空
  2. 取出尾部節點
  3. 判斷尾部節點的上一個節點是否存在
    1. 不存在:則說明只有一個節點, 刪除本身,無須移動指針位置
    2. 如果存在上一個節點,則尾部的上一個節點即是尾部節點.
//刪除尾部節點
func (list *DoubleList) RemoveTail() *DoubleNode {
  //判斷尾部節點是否為空
  if list.Tail == nil {
    return nil
  }
  list.lock.Lock()
  defer list.lock.Unlock()
  //取出尾部節點
  node := list.Tail
  //判斷尾部節點的上一個是否存在
  if node.Prev != nil {
    list.Tail = node.Prev
    list.Tail.Next = nil
  }
  list.Size--
  return node
}

刪除任意元素

實現思路

  1. 判斷是否是頭部節點
  2. 判斷是否是尾部節點
  3. 否則為中間節點,需要移動上下節點的指針位置.并實現元素刪除
    1. 將上一個節點的下一節點指針指向下節點
    2. 將下一個節點的上一節點指針指向上節點
//刪除任意元素
func (list *DoubleList) Remove(node *DoubleNode) *DoubleNode {
  //判斷是否是頭部節點
  if node == list.Head {
    return list.RemoveHead()
  }
  //判斷是否是尾部節點
  if node == list.Tail {
    return list.RemoveTail()
  }
  list.lock.Lock()
  defer list.lock.Unlock()
  //節點為中間節點
  //則需要:
  //將上一個節點的下一節點指針指向下節點
  //將下一個節點的上一節點指針指向上節點
  node.Prev.Next = node.Next
  node.Next.Prev = node.Prev
  list.Size--
  return node
}

查看完整源碼

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 詳解go語言單鏈表及其常用方法的實現
  • python/golang 刪除鏈表中的元素
  • python/golang實現循環鏈表的示例代碼
  • Go實現雙向鏈表的示例代碼
  • Go語言單鏈表實現方法
  • go實現反轉鏈表

標簽:東營 許昌 貴州 常州 曲靖 德宏 吐魯番 保定

巨人網絡通訊聲明:本文標題《golang雙鏈表的實現代碼示例》,本文關鍵詞  golang,雙鏈,表,的,實現,代碼,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang雙鏈表的實現代碼示例》相關的同類信息!
  • 本頁收集關于golang雙鏈表的實現代碼示例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美亚洲国产一区二区三区| 成人理论电影网| 日韩一区二区在线免费观看| 99久久精品久久久久久清纯| 国产成人精品影视| 成人免费视频视频| aaa欧美日韩| 91小视频在线| 欧美日韩视频在线第一区| 色8久久精品久久久久久蜜| 91视频在线观看| 91久久线看在观草草青青| 色94色欧美sute亚洲线路二| 欧美网站一区二区| 欧美一级欧美三级| 日韩午夜在线影院| 国产午夜精品久久久久久免费视| 国产亚洲短视频| 亚洲欧美一区二区三区久本道91| 一区二区三区在线视频免费观看| 三级久久三级久久久| 精品无人码麻豆乱码1区2区| 国产伦精品一区二区三区在线观看| 国产激情精品久久久第一区二区 | 欧美性大战久久| 欧美日韩成人在线| 26uuu欧美| 亚洲日本乱码在线观看| 日韩激情视频在线观看| 国产a区久久久| 欧美性猛交xxxxxx富婆| 精品区一区二区| 亚洲精品一卡二卡| 精品一区免费av| 91色.com| 久久久久国产精品免费免费搜索| 玉米视频成人免费看| 青青草精品视频| 色诱亚洲精品久久久久久| 欧美一区二区播放| 亚洲欧洲日韩综合一区二区| 久久精品国产秦先生| 99国产精品久久久久久久久久 | 精品一区二区三区香蕉蜜桃| 99久久国产综合精品麻豆| 日韩一区二区三区在线观看| 亚洲欧美日韩小说| 国产成人精品综合在线观看| 91精品在线观看入口| 国产精品乱人伦中文| 国模一区二区三区白浆| 欧美日韩亚洲不卡| 亚洲美女在线一区| 国产精品18久久久久| 6080日韩午夜伦伦午夜伦| 亚洲乱码国产乱码精品精98午夜| 国产一区二区中文字幕| 日韩欧美一二区| 日韩电影在线看| 91久久线看在观草草青青| 国产精品毛片无遮挡高清| 国内精品视频666| 欧美一级夜夜爽| 亚洲一区二区四区蜜桃| 91在线视频官网| 国产欧美精品一区二区三区四区 | 91同城在线观看| 欧美国产精品专区| 国产精品综合二区| 337p粉嫩大胆噜噜噜噜噜91av| 三级不卡在线观看| 在线播放欧美女士性生活| 亚欧色一区w666天堂| 欧美人牲a欧美精品| 亚洲国产成人av网| 91精品国产黑色紧身裤美女| 偷窥国产亚洲免费视频| 91精品国产一区二区| 青草国产精品久久久久久| 91精品国产综合久久久久久久久久| 香蕉av福利精品导航| 91精品国产乱| 国产一区欧美二区| 中文字幕视频一区二区三区久| 99久久综合狠狠综合久久| 亚洲丝袜自拍清纯另类| 欧美怡红院视频| 婷婷成人激情在线网| 欧美一卡二卡在线观看| 精品午夜久久福利影院| 欧美激情资源网| 色婷婷久久久久swag精品| 亚洲综合无码一区二区| 日韩一区二区在线观看| 国产精品一区二区三区四区| 国产精品久久久久久久久免费相片| 91无套直看片红桃| 日本美女一区二区| 国产三级一区二区三区| 一本色道久久综合精品竹菊| 日韩国产欧美在线视频| 国产亲近乱来精品视频| 一本大道久久a久久综合| 免费成人在线视频观看| 中文幕一区二区三区久久蜜桃| 91色综合久久久久婷婷| 看片的网站亚洲| 国产精品久久久久久久久免费丝袜| 欧美中文字幕一区| 国产一区二区不卡老阿姨| 亚洲人午夜精品天堂一二香蕉| 欧美二区三区91| 国产aⅴ综合色| 日韩不卡手机在线v区| 日本一区免费视频| 日韩色在线观看| 色狠狠一区二区三区香蕉| 国产一区二三区| 婷婷久久综合九色综合伊人色| 国产精品无码永久免费888| 91精品一区二区三区在线观看| 99久久免费国产| 国产乱子伦一区二区三区国色天香| 玉足女爽爽91| 国产精品久久久久久亚洲毛片| 日韩一级成人av| 欧美日韩一区二区三区四区五区| 国产黄色精品网站| 九九九精品视频| 无码av免费一区二区三区试看 | 视频一区在线播放| 一区视频在线播放| 国产日本一区二区| 国产婷婷一区二区| 久久久久久亚洲综合| 日韩视频免费观看高清完整版在线观看 | 97久久人人超碰| 成人夜色视频网站在线观看| 久久成人综合网| 狂野欧美性猛交blacked| 日韩不卡免费视频| 午夜成人在线视频| 五月综合激情网| 亚洲国产另类精品专区| 一级中文字幕一区二区| 一区在线观看视频| 最新国产成人在线观看| 国产精品情趣视频| 国产日韩在线不卡| 国产精品青草综合久久久久99| 国产色综合一区| 国产精品国产a级| 亚洲免费观看在线视频| 亚洲精选视频在线| 亚洲电影在线播放| 天天综合日日夜夜精品| 日本一道高清亚洲日美韩| 日韩在线观看一区二区| 日本成人中文字幕在线视频| 日韩二区三区在线观看| 蜜桃视频免费观看一区| 久久99国产精品免费| 国产东北露脸精品视频| 成人久久视频在线观看| 日本韩国欧美一区二区三区| 欧美人与性动xxxx| www国产成人| 国产精品国产三级国产三级人妇| 亚洲色图19p| 青青草原综合久久大伊人精品 | 7799精品视频| 久久免费偷拍视频| 亚洲免费观看视频| 免费精品视频在线| 丰满亚洲少妇av| 欧美日韩精品一区二区三区四区| 在线播放日韩导航| 亚洲国产精品av| 肉色丝袜一区二区| 丁香六月久久综合狠狠色| 在线看日韩精品电影| 精品剧情在线观看| 亚洲免费资源在线播放| 看电视剧不卡顿的网站| 成人高清免费在线播放| 欧美精品v日韩精品v韩国精品v| 久久久不卡影院| 亚洲成人中文在线| 成人国产电影网| 欧美一区二区视频在线观看| 国产精品国产a级| 精品在线观看视频| 日本韩国欧美一区二区三区| 久久无码av三级| 首页国产欧美久久| 91麻豆蜜桃一区二区三区| 亚洲精品在线三区| 亚洲国产va精品久久久不卡综合| 国产成人av资源| 欧美成人性福生活免费看|