国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

python/golang實現循環鏈表的示例代碼

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

循環鏈表就是將單鏈表的末尾指向其頭部,形成一個環。循環鏈表的增刪操作和單鏈表的增刪操作區別不大。只是增加時,需要考慮空鏈表增加第一個節點的特殊情況;刪除時需考慮刪除節點是頭/尾節點,和鏈表中只有一個節點的特殊情況。

golang實現:

type Node struct { value int next *Node}type Circle struct { tail *Node lenth int}// 增加節點:func (c *Circle) add(value int) { newNode := &Node{value, nil} if c.lenth == 0 { //空鏈表中添加節點 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()}// 刪除節點:func (c *Circle) remove(v int) { if c.lenth == 0 { fmt.Println('空環') return } else if c.lenth == 1 && c.tail.value == v { //鏈表中只有一個節點的特殊情況 c.tail = nil c.lenth = 0 c.printCircle() return } pre := c.tail cur := c.tail.next // 頭節點 for i := 0; i < c.lenth; i++ { if cur.value == v { if cur == c.tail { //如果刪除的節點是尾節點,需更新tail c.tail = pre } pre.next = cur.next c.lenth -= 1 c.printCircle() return } pre = cur cur = cur.next } fmt.Println(v, '不在環中')}//打印節點:func (c *Circle) printCircle() { if c.lenth == 0 { fmt.Println('空環') return } cur := c.tail.next // 頭節點 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實現:

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 # 增加節點 def add(self, v): new_node = Node(v) if self.lenth == 0: # 空鏈表中添加節點 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 # 刪除節點 def remove(self, v): if self.lenth == 0: print('空環') return elif self.lenth == 1 and self.tail.value == v: # 鏈表中只有一個節點的特殊情況 self.tail = None self.lenth = 0 return pre = self.tail cur = self.tail.next # 頭節點 for i in range(self.lenth): if cur.value == v: if cur == self.tail: # 如果刪除的節點是尾節點,需更新tail self.tail = pre pre.next = cur.next self.lenth -= 1 return pre = cur cur = cur.next print(v, '不在環中') # 打印鏈表 def print_circle(self): if self.lenth == 0: print(’空環’) return cur = self.tail.next # 頭節點 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實現循環鏈表的示例代碼的詳細內容,更多關于python/golang 循環鏈表的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲自拍图片区 | 揉揉胸摸腿摸下面va视频 | 国产资源免费 | 国产91精选在线观看网站 | 亚洲欧美综合一区二区三区四区 | 香蕉97碰碰视频免费 | 美国三级网 | 国内免费视频成人精品 | 亚洲高清一区二区三区四区 | 久久亚洲精品永久网站 | 女人张开双腿让男人桶完整 | 久久www免费人成_看片高清 | 福利91| 欧美一级毛片片免费 | 欧美日韩免费一区二区三区 | 国产一级二级三级毛片 | 毛片视频免费观看 | 免费一级欧美大片视频在线 | 一级片免费观看视频 | 日韩免费a级在线观看 | 精品久久国产老人久久综合 | 亚洲一区二区三区在线播放 | 久久国产精品久久久久久久久久 | 国产香蕉国产精品偷在线观看 | 国产精品久久久久久影视 | 欧美一级久久久久久久大 | 国产午夜爽爽窝窝在线观看 | 日韩欧美一区二区精品久久 | 国产精品久久久久久爽爽爽 | 日本高清在线精品一区二区三区 | 国产精品不卡在线 | 日本精品久久久久久久 | 日韩一区二区在线免费观看 | 日本一级毛片视频无遮挡免费 | 中国国产成人精品久久 | 欧美成国产精品 | 国产综合久久久久影院 | 国产精品久久久久亚洲 | 欧美特黄一片aa大片免费看 | 美女又爽又黄视频 | 国产成人精品亚洲日本在线观看 |