av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

python/golang實(shí)現(xiàn)循環(huán)鏈表的示例代碼

瀏覽:5日期:2022-07-11 11:42:27

循環(huán)鏈表就是將單鏈表的末尾指向其頭部,形成一個(gè)環(huán)。循環(huán)鏈表的增刪操作和單鏈表的增刪操作區(qū)別不大。只是增加時(shí),需要考慮空鏈表增加第一個(gè)節(jié)點(diǎn)的特殊情況;刪除時(shí)需考慮刪除節(jié)點(diǎn)是頭/尾節(jié)點(diǎn),和鏈表中只有一個(gè)節(jié)點(diǎn)的特殊情況。

golang實(shí)現(xiàn):

type Node struct { value int next *Node}type Circle struct { tail *Node lenth int}// 增加節(jié)點(diǎn):func (c *Circle) add(value int) { newNode := &Node{value, nil} if c.lenth == 0 { //空鏈表中添加節(jié)點(diǎn) c.tail = newNode c.tail.next = newNode } else { newNode.next = c.tail.next c.tail.next = newNode c.tail = newNode } c.lenth += 1 c.printCircle()}// 刪除節(jié)點(diǎn):func (c *Circle) remove(v int) { if c.lenth == 0 { fmt.Println('空環(huán)') return } else if c.lenth == 1 && c.tail.value == v { //鏈表中只有一個(gè)節(jié)點(diǎn)的特殊情況 c.tail = nil c.lenth = 0 c.printCircle() return } pre := c.tail cur := c.tail.next // 頭節(jié)點(diǎn) for i := 0; i < c.lenth; i++ { if cur.value == v { if cur == c.tail { //如果刪除的節(jié)點(diǎn)是尾節(jié)點(diǎn),需更新tail c.tail = pre } pre.next = cur.next c.lenth -= 1 c.printCircle() return } pre = cur cur = cur.next } fmt.Println(v, '不在環(huán)中')}//打印節(jié)點(diǎn):func (c *Circle) printCircle() { if c.lenth == 0 { fmt.Println('空環(huán)') return } cur := c.tail.next // 頭節(jié)點(diǎn) for i := 0; i < c.lenth; i++ { fmt.Printf('%d ', cur.value) cur = cur.next } fmt.Println()}func testCircle() { var circle *Circle = new(Circle) //for i := 1; i <=41; i++ { // circle.add(i) //} circle.add(1) circle.remove(10) circle.printCircle()}

python實(shí)現(xiàn):

class Node: def __init__(self, value, next=None): self.value = value self.next = next def __str__(self): return str(self.value)class Circle: def __init__(self): self.tail = None self.lenth = 0 # 增加節(jié)點(diǎn) def add(self, v): new_node = Node(v) if self.lenth == 0: # 空鏈表中添加節(jié)點(diǎn) self.tail = new_node self.tail.next = new_node else: new_node.next = self.tail.next self.tail.next = new_node self.tail = new_node self.lenth += 1 # 刪除節(jié)點(diǎn) def remove(self, v): if self.lenth == 0: print('空環(huán)') return elif self.lenth == 1 and self.tail.value == v: # 鏈表中只有一個(gè)節(jié)點(diǎn)的特殊情況 self.tail = None self.lenth = 0 return pre = self.tail cur = self.tail.next # 頭節(jié)點(diǎn) for i in range(self.lenth): if cur.value == v: if cur == self.tail: # 如果刪除的節(jié)點(diǎn)是尾節(jié)點(diǎn),需更新tail self.tail = pre pre.next = cur.next self.lenth -= 1 return pre = cur cur = cur.next print(v, '不在環(huán)中') # 打印鏈表 def print_circle(self): if self.lenth == 0: print(’空環(huán)’) return cur = self.tail.next # 頭節(jié)點(diǎn) for i in range(self.lenth): print(cur, end=' ') cur = cur.next print()def test(): c = Circle() for i in range(10): c.add(i) c.print_circle() c.remove(0) c.print_circle() c.remove(10) c.print_circle() c.remove(9) c.print_circle() c.remove(4) c.print_circle()

以上就是python/golang實(shí)現(xiàn)循環(huán)鏈表的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于python/golang 循環(huán)鏈表的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 爱操av | 久久综合狠狠综合久久综合88 | 国产精品久久一区二区三区 | 天天操 天天操 | 久久99精品久久久97夜夜嗨 | 丝袜美腿一区二区三区动态图 | 国产一级淫片a直接免费看 免费a网站 | 黄a在线观看 | 久久久青草婷婷精品综合日韩 | 在线观看成人小视频 | 亚洲视频免费观看 | 亚洲精品1区| www.久| 91tv在线观看 | 国产成人精品视频在线观看 | 国产一级黄色网 | 欧美日高清 | 精品国产乱码久久久久久蜜臀 | 久久国产视频网站 | 伊人网伊人 | 欧美激情亚洲天堂 | 国产美女自拍视频 | 精品日韩| 久久久精品一区 | 欧美黑人激情 | 免费观看一级特黄欧美大片 | 先锋av资源在线 | av在线免费播放 | 日韩精品一区二区三区中文在线 | 九七午夜剧场福利写真 | av手机免费在线观看 | 中日字幕大片在线播放 | 一级一级毛片免费看 | 国产亚洲精品久久yy50 | 精品国产乱码久久久久久蜜退臀 | 午夜电影在线播放 | 久草在线免费资源 | 亚洲欧美国产精品久久 | 亚洲一区二区三区在线免费 | 亚洲国产精品一区二区久久 | 免费观看一级毛片 |