精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Python數據結構之單鏈表

開發 后端
單向鏈表(單鏈表)是鏈表的一種,其特點是鏈表的鏈接方向是單向的,對鏈表的訪問要通過順序讀取從頭部開始。單鏈表是一種鏈式存取的數據結構,用一組地址任意的存儲單元存放線性表中的數據元素。

[[410894]]

本文轉載自微信公眾號「python與大數據分析」,作者一只小小鳥鳥。轉載本文請聯系python與大數據分析公眾號。

今天終于把大學都沒想明白的鏈表數據結構整明白了,也算小小的收獲,挺好玩的。文后附鏈表操作示意圖。

單向鏈表(單鏈表)是鏈表的一種,其特點是鏈表的鏈接方向是單向的,對鏈表的訪問要通過順序讀取從頭部開始。單鏈表是一種鏈式存取的數據結構,用一組地址任意的存儲單元存放線性表中的數據元素。

鏈表中的數據是以結點來表示的,每個結點的構成:元素(數據元素的映象) + 指針(指示后繼元素存儲位置),元素就是存儲數據的存儲單元,指針就是連接每個結點的地址數據。它的每個節點包含兩個域,一個信息域(元素域)和一個鏈接域。這個鏈接指向鏈表中的下一個節點,而最后一個節點的鏈接域則指向一個空值。

  • isempty(self) 鏈表是否為空
  • length(self) 鏈表長度
  • travel(self) 遍歷整個鏈表
  • add(self,item) 鏈表頭部添加元素
  • append(self,item) 鏈表尾部添加元素
  • insert(self,item,index) 指定位置添加元素
  • deletebyitem(self,item) 根據數據項刪除節點
  • deletebyindex(self,index) 根據索引位置刪除節點
  • search(self,item) 根據數據項查找節點是否存在
  • update(self,index,item) 暫無實現
  • getitem(self,index) 獲取索引位置對應的數據項
  • getindex(self,item) 獲取數據項對應的索引位置

代碼基本為原創,經過大量重寫

  1. class Node(object): 
  2.     def __init__(self, item): 
  3.         self.item = item 
  4.         self.next = None 
  5.     def __repr__(self): 
  6.         pass 
  7.     def __str__(self): 
  8.         return str(self.item) 
  9.  
  10. class SingleLinkList(object): 
  11.     def __init__(self): 
  12.         self.header = None 
  13.         self.currentnum=0 
  14.  
  15.     def isempty(self): 
  16.         return self.header == None 
  17.  
  18.     def length(self): 
  19.         return self.currentnum 
  20.  
  21.     def travel(self): 
  22.         cur =self.header 
  23.         while cur !=None: 
  24.             print("{}".format(cur.item),end=" "
  25.             cur=cur.next 
  26.         print("\r"
  27.  
  28.     def add(self,item): 
  29.         node=Node(item) 
  30.         # 新節點的鏈接指向頭節點 
  31.         node.next=self.header 
  32.         # 鏈表的頭指向新節點 
  33.         self.header=node 
  34.         self.currentnum+=1 
  35.  
  36.     def append(self,item): 
  37.         tempnode=self.header 
  38.         node=Node(item) 
  39.         if self.isempty(): 
  40.             self.add(node) 
  41.         else
  42.             while tempnode.next!=None: 
  43.                 tempnode=tempnode.next 
  44.             tempnode.next=node 
  45.             self.currentnum+=1 
  46.  
  47.     def insert(self,item,index): 
  48.         node=Node(item) 
  49.         tempnode=self.header 
  50.         if index>self.currentnum+1 or index<=0: 
  51.             raise IndexError("{} is not find in Linklist".format(index)) 
  52.         # 指定位置為第一個即在頭部插入 
  53.         if index==1: 
  54.             self.add(node) 
  55.         elif index>self.currentnum-1: 
  56.             self.append(node) 
  57.         else
  58.             for i in range(1,index-1): 
  59.                 tempnode=tempnode.next 
  60.             node.next=tempnode.next 
  61.             tempnode.next=node 
  62.             self.currentnum+=1 
  63.  
  64.     def deletebyitem(self,item): 
  65.         tempnode=self.header 
  66.         prenode=None 
  67.         while tempnode!=None: 
  68.             if tempnode.item==item: 
  69.                 if tempnode==self.header: 
  70.                     self.header=tempnode.next 
  71.                 else
  72.                     prenode.next=tempnode.next 
  73.                 break 
  74.             else
  75.                 prenode=tempnode 
  76.                 tempnode=tempnode.next 
  77.  
  78.  
  79.     def deletebyindex(self,index): 
  80.  
  81.         if index>self.currentnum or index<=0: 
  82.             raise IndexError("{} is not find in Linklist".format(index)) 
  83.  
  84.         i=1 
  85.         tempnode=self.header 
  86.         prenode=self.header 
  87.  
  88.         if index==1: 
  89.             self.header = tempnode.next 
  90.             self.currentnum-=1 
  91.             return 
  92.  
  93.         while tempnode.next and i<index
  94.             prenode = tempnode 
  95.             tempnode = tempnode.next 
  96.             i+=1 
  97.  
  98.         if i==index
  99.             prenode.next=tempnode.next 
  100.             self.currentnum-=1 
  101.  
  102.  
  103.     def search(self,item): 
  104.         tempnode=self.header 
  105.         while tempnode!=None: 
  106.             if tempnode.item==item: 
  107.                 return True 
  108.             else
  109.                 tempnode=tempnode.next 
  110.         return False 
  111.  
  112.     def update(self,index,item): 
  113.         pass 
  114.  
  115.     def getitem(self,index): 
  116.         if index<=0 or index>self.currentnum: 
  117.             raise IndexError("{} is not find in Linklist".format(index)) 
  118.         tempnode=self.header 
  119.         i=1 
  120.         while i<index
  121.             tempnode=tempnode.next 
  122.             i+=1 
  123.         return tempnode.item 
  124.  
  125.     def getindex(self,item): 
  126.         tempnode = self.header 
  127.         i=0 
  128.         flag=False 
  129.         while tempnode != None: 
  130.             i+=1 
  131.             if tempnode.item == item: 
  132.                 flag=True 
  133.                 return i 
  134.             else
  135.                 tempnode = tempnode.next 
  136.         if flag==False
  137.             return 0 
  138.  
  139. if __name__ == '__main__'
  140.     a = SingleLinkList() 
  141.     a.add(1)  # 1 
  142.     print('a.add(1)'
  143.     a.travel() 
  144.     a.add(2)  # 2 1 
  145.     print('a.add(2)'
  146.     a.travel() 
  147.     a.append(3)  # 2 1 3 
  148.     print('a.append(3)'
  149.     a.travel() 
  150.     a.insert(4, 2)  # 2 1 4 3 
  151.     print('a.insert(2, 4)'
  152.     a.travel() 
  153.     print('a.search(1)=',a.search(1)) 
  154.     print('a.search(5)=', a.search(5)) 
  155.     print('a.getindex(1)=',a.getindex(1)) 
  156.     print('a.getindex(5)=', a.getindex(5)) 
  157.     print('a.getitem(2)=', a.getitem(2)) 
  158.     print('a.getitem(4)=', a.getitem(4)) 
  159.     print('a.getitem(3)=', a.getitem(3)) 
  160.     # a.deletebyitem(5) 
  161.     # print('a.deletebyitem(5)'
  162.     # a.travel() 
  163.     # a.deletebyitem(4) 
  164.     # print('a.deletebyitem(4)'
  165.     # a.travel() 
  166.     # a.deletebyitem(2) 
  167.     # print('a.deletebyitem(2)'
  168.     # a.travel() 
  169.     a.deletebyindex(4) 
  170.     print('a.deletebyindex(4)'
  171.     a.travel() 
  172.     a.deletebyindex(2) 
  173.     print('a.deletebyindex(2)'
  174.     a.travel() 
  175.     a.deletebyindex(1) 
  176.     print('a.deletebyindex(1)'
  177.     a.travel() 

結果如下

  1. C:\python\pyproject\pythonalgorithms\venv\Scripts\python.exe C:/python/pyproject/pythonalgorithms/linklist.py 
  2. a.add(1) 
  3. 1  
  4. a.add(2) 
  5. 2 1  
  6. a.append(3) 
  7. 2 1 3  
  8. a.insert(2, 4) 
  9. 2 4 1 3  
  10. a.search(1)= True 
  11. a.search(5)= False 
  12. a.getindex(1)= 3 
  13. a.getindex(5)= 0 
  14. a.getitem(2)= 4 
  15. a.getitem(4)= 3 
  16. a.getitem(3)= 1 
  17. a.deletebyindex(4) 
  18. 2 4 1  
  19. a.deletebyindex(2) 
  20. 2 1  
  21. a.deletebyindex(1) 
  22. 1  
  23.  
  24. Process finished with exit code 0 

鏈表頭部增加節點示意圖

從鏈表尾部增加節點示意圖

 

責任編輯:武曉燕 來源: python與大數據分析
相關推薦

2012-02-02 10:21:05

單鏈表nexthead

2021-07-15 06:43:12

Python數據結構

2017-03-01 13:58:46

Python數據結構鏈表

2021-03-10 08:42:19

Java數據結構算法

2021-08-03 10:24:59

數據跳躍鏈表結構

2021-05-12 14:09:35

鏈表數據結構線性結構

2021-04-12 15:47:00

數據結構算法鏈表

2021-07-16 07:57:34

Python數據結構

2021-12-21 08:19:29

數據結構算法鏈表相交

2020-10-28 10:10:03

Java單鏈表數據結構

2021-10-29 11:27:52

鏈表數據結構算法

2021-01-06 08:03:00

JavaScript數據結構

2021-07-11 12:06:43

python數據結構

2021-01-28 07:33:34

JavaScript鏈表數據

2023-03-28 07:44:23

數據結構數組

2023-10-06 20:21:28

Python鏈表

2009-07-02 14:59:28

Java考研試題

2018-06-06 08:54:23

數據結構存儲

2024-10-11 16:43:05

高并發數據結構技巧

2022-01-18 19:13:52

背包問題數據結構算法
點贊
收藏

51CTO技術棧公眾號

国产又粗又长又爽视频| 欧美成人小视频| 欧美视频第三页| 极品美乳网红视频免费在线观看 | 久久精品magnetxturnbtih| 日韩欧美一级视频| 视频国产一区| 欧美久久久一区| www.国产在线视频| 牛牛影视精品影视| 久久99久久久久久久久久久| 欧美激情亚洲综合一区| 亚洲乱码国产乱码精品精大量| 校园春色亚洲色图| 一区二区三区在线不卡| 精品区一区二区| 三级在线免费观看| 婷婷在线免费观看| 蜜臀av一区二区| 久久久久久久久网站| 欧美色图亚洲激情| 97成人超碰| 亚洲444eee在线观看| 日韩欧美亚洲在线| 丰满人妻妇伦又伦精品国产| 久久精品国产清高在天天线| 亚洲一二在线观看| 午夜dv内射一区二区| 欧美寡妇性猛交xxx免费| 91麻豆精东视频| 亚洲综合第一页| 中文字幕精品视频在线观看| 激情婷婷欧美| 久久精品中文字幕电影| 涩视频在线观看| 色狠狠一区二区三区| 欧美午夜精品伦理| 久久av综合网| 亚洲www色| 国产精品视频免费| 蜜桃传媒视频麻豆一区| 国产成人毛毛毛片| 美女看a上一区| 日本91av在线播放| 日韩a级片在线观看| 日本在线电影一区二区三区| 日韩高清免费观看| 手机看片国产精品| 日韩毛片免费视频一级特黄| 色婷婷久久久久swag精品| 美女黄色免费看| 国产福利视频在线观看| 中文字幕av不卡| 日本一区二区久久精品| 少妇精品视频一区二区| 国产成人精品午夜视频免费| 成人亲热视频网站| 在线播放成人av| 青椒成人免费视频| 国产成人综合精品| 波多野结衣视频在线观看| 国产又黄又大又粗的视频| 亚洲男女av一区二区| 正在播放欧美视频| 欧洲av一区二区三区| 先锋影音国产精品| 日韩精品高清在线观看| 国产视频精品视频| 国产精品99久久免费观看| 日韩精品中文字幕在线一区| 久久精品无码一区二区三区毛片| 2020国产精品小视频| 欧美精品在线观看一区二区| 欧美成年人视频在线观看| 日本美女久久| 欧美日韩国产天堂| 国产欧美精品一二三| 国产精品xnxxcom| 欧美一区二区视频网站| 做a视频在线观看| 国产亚洲精彩久久| 日韩区在线观看| 强迫凌虐淫辱の牝奴在线观看| 亚洲另类av| 久久精品久久精品亚洲人| 免费一级全黄少妇性色生活片| 国产亚洲综合精品| 成人亚洲欧美一区二区三区| 黄色福利在线观看| 国产欧美1区2区3区| 三级网在线观看| 国产一二在线播放| 欧美日韩精品专区| 97人妻精品一区二区三区免费| 国产伦精品一区二区三区千人斩| 欧美床上激情在线观看| 国产精品一区无码| 国产精品99久久久久久宅男| 麻豆91蜜桃| 少女频道在线观看免费播放电视剧| 色婷婷av一区二区三区大白胸| 热久久久久久久久| 免费一区二区| 久久久久久久国产| 最新中文字幕在线观看视频| 成人久久18免费网站麻豆| 亚欧洲精品在线视频免费观看| 激情影院在线| 欧美群妇大交群的观看方式| 亚洲熟妇一区二区三区| 欧美日韩国产色综合一二三四| 国产精品久久999| 男人天堂一区二区| 亚洲欧美自拍偷拍色图| 欧美牲交a欧美牲交aⅴ免费下载| 亚洲国产中文在线二区三区免| 伊人亚洲福利一区二区三区| 国产无码精品在线播放| 激情欧美一区二区| 色一情一乱一伦一区二区三区| 国产探花视频在线观看| 日韩一区二区在线看| 纪美影视在线观看电视版使用方法| 99这里有精品| 国产日韩亚洲精品| 色婷婷av在线| 欧美一二三区在线| 人人澡人人澡人人看| 日韩精品亚洲一区| 欧洲亚洲一区二区三区四区五区| 2021中文字幕在线| 亚洲精品在线网站| 久久久久久久久精| 国产精品系列在线观看| 黄色a级在线观看| 四虎国产精品永久在线国在线 | 午夜视频在线免费看| 色综合天天爱| 国产精品网址在线| 91高清在线| 欧美剧情片在线观看| 欧美人妻一区二区三区| 视频一区二区三区中文字幕| 久久99九九| 亚洲天堂资源| 国产亚洲精品久久久优势| 日韩 国产 欧美| 久久久国产综合精品女国产盗摄| 妞干网在线免费视频| 久久av综合| 国产精品久久久久久五月尺| 在线日本视频| 欧美一级xxx| 欧美成人三级视频| 风流少妇一区二区| 精品国产91久久久久久老师| 国产无套内射久久久国产| 神马香蕉久久| 国产成人91久久精品| 福利视频在线导航| 欧美日韩国产高清一区二区三区 | 麻豆成人在线播放| 欧美xxxx做受欧美护士| 中文字幕日韩综合av| 国产一区二区三区在线观看| 亚洲色图都市小说| 最新中文字幕日本| 久久人人超碰| 亚洲成年人专区| 最新精品在线| 国产91精品最新在线播放| av大全在线免费看| 日韩免费高清av| 亚洲黄色免费观看| 国产精品视频免费| 国产精品91av| 久久精选视频| 成人在线免费观看网址| 久久91在线| 国产精品欧美日韩一区二区| 成a人片在线观看| 亚洲精品www久久久| 波多野结衣在线电影| 亚洲欧洲精品一区二区精品久久久| 扒开伸进免费视频| 天堂av在线一区| 日韩欧美一级在线| 免费成人网www| 亚洲综合在线小说| 亚洲精品一级二级| 久久99久久99精品免观看粉嫩| 欧美视频综合| 日韩视频在线你懂得| 亚洲精品91天天久久人人| 亚洲一区免费观看| 91视频免费看片| 99精品久久99久久久久| 亚洲久久中文字幕| 国产一区二区精品| 桥本有菜av在线| 婷婷综合成人| 97超级在线观看免费高清完整版电视剧| 一个人看的www视频在线免费观看| y97精品国产97久久久久久| 天堂网在线中文| 制服丝袜亚洲精品中文字幕| 日本在线播放视频| 夜夜精品视频一区二区| 欧美激情视频二区| 91尤物视频在线观看| 国产人妖在线观看| 久久国产剧场电影| 国产a视频免费观看| 激情成人亚洲| 在线观看17c| 国产精品精品国产一区二区| 日本成人黄色| 欧美精品第一区| 国产日韩一区欧美| 日本亚州欧洲精品不卡| 国产日本欧美在线观看| 日韩久久一区二区三区| 欧美亚洲午夜视频在线观看| 美女91在线| 欧美成人午夜剧场免费观看| 老司机在线视频二区| 在线中文字幕日韩| 国产二区视频在线观看| 亚洲精品视频中文字幕| 香蕉视频免费在线看| 亚洲二区中文字幕| 亚洲精品一区二区三区蜜桃| 日韩午夜电影av| a在线观看免费| 91精品国产乱码久久蜜臀| 夜夜躁狠狠躁日日躁av| 欧美色视频一区| 在线观看中文字幕av| 欧美午夜片在线看| 羞羞色院91蜜桃| 精品视频一区二区三区免费| 国产一级片一区二区| 欧美色国产精品| 国产又大又长又粗| 日韩欧美一级片| 色wwwwww| 亚洲码在线观看| 成年网站在线| 国产一区二区三区中文 | 欧美日韩麻豆| 精品久久一区二区三区蜜桃| 少妇精品导航| 欧美日韩在线观看一区| 精品久久综合| 亚洲一区三区视频在线观看| 98精品久久久久久久| 一区二区在线观| 欧美色图首页| 色综合久久综合网97色综合 | 亚洲AV无码成人片在线观看| 欧美videossexotv100| 三级小视频在线观看| 亚洲人成电影在线| 97超碰国产一区二区三区| 久久亚洲综合国产精品99麻豆精品福利 | 国产成人免费视频一区| a级一a一级在线观看| www日韩大片| 91视频免费看片| 亚洲综合免费观看高清完整版在线 | 国产日韩中文在线| 欧美日本三级| 久久久久久国产精品mv| 久久国产成人午夜av影院宅| 日韩亚洲欧美一区二区| 性8sex亚洲区入口| av在线网址导航| 处破女av一区二区| 亚洲一区二区自偷自拍 | 日韩精品久久久久久久| 在线视频一区二区三区| 国产一区二区视频免费观看| 亚洲国产精久久久久久久| www.亚洲免费| 久久久久久久久久国产| 欧美性片在线观看| 高清不卡一区二区三区| 精品一区电影| 国产一线二线三线女| 美腿丝袜一区二区三区| 91精品啪在线观看国产| 国产精品国产三级国产专播品爱网| 国产亚洲精品女人久久久久久| 91福利视频久久久久| 后进极品白嫩翘臀在线视频| 中文字幕无线精品亚洲乱码一区 | 免费成人在线影院| 亚洲少妇一区二区三区| 中文字幕中文在线不卡住| 欧美亚韩一区二区三区| 欧美人xxxx| 国产天堂在线| 97香蕉超级碰碰久久免费的优势| 日本a人精品| 日韩av观看网址| 哺乳一区二区三区中文视频| 亚洲一区在线免费| 久久狠狠一本精品综合网| 久久久久久久久久久久国产精品| 国产精品欧美一区二区三区| 久久免费激情视频| 日韩精品一区二区三区在线观看| 97超碰人人在线| 日韩av123| 欧美天堂社区| 国产天堂视频在线观看| 国产一区高清在线| 成人午夜免费影院| 欧美性猛交xxxx黑人交| 亚洲国产午夜伦理片大全在线观看网站| 日韩欧美电影| 亚洲精品一二三四五区| 91丨九色丨国产丨porny| 久久精品国产亚洲AV无码男同 | 欧美国产精品| 粉色视频免费看| 中文在线资源观看网站视频免费不卡| 久草视频在线观| 精品久久人人做人人爰| 黄色片网站在线| 国产在线精品一区免费香蕉 | www成人免费| 国内精品免费在线观看| 日本伦理一区二区三区| 欧美怡红院视频| 东热在线免费视频| 国产91在线高潮白浆在线观看| 美女呻吟一区| av免费观看大全| eeuss国产一区二区三区| 久久久久久久国产精品毛片| 日韩免费看网站| 国产一线二线在线观看| 91久久精品国产91久久性色tv| 欧美黄色大片网站| 91精品人妻一区二区三区四区| 亚洲一卡二卡三卡四卡五卡| 高清国产mv在线观看| 久久久噜噜噜久久久| 亚洲都市激情| 爱情岛论坛成人| 国产精品美女久久久久久久久| 国产一区二区三区在线观看| 美女扒开尿口让男人操亚洲视频网站| 日本在线视频一区二区三区| 国产资源第一页| 99久久精品国产导航| 在线免费黄色av| 日韩中文在线视频| 久久伊人影院| 国产在线一区二区三区播放| 免费一区二区三区四区| 五月天亚洲综合| 久久99深爱久久99精品| 午夜免费激情视频| 91精品国产91综合久久蜜臀| 天堂8中文在线| 精品国产区在线| 日韩精品乱码av一区二区| 精品熟妇无码av免费久久| 91精品国产综合久久久久久久| 污污的网站在线免费观看| 精品久久久久久亚洲| 日韩电影在线观看一区| 一区二区三区在线播放视频| 欧美一区二区三区视频免费播放| 日本h片在线观看| 欧美精品一区二区三区四区五区| 美女网站视频久久| 精品无码久久久久久久久| 国产丝袜高跟一区| 久久影视精品| 男女激情无遮挡| 国产精品美女久久久久aⅴ国产馆| 精品人妻一区二区三区三区四区| 777国产偷窥盗摄精品视频| 热久久天天拍国产| 亚洲AV成人精品| 欧美性猛交xxxx黑人猛交| 麻豆影视国产在线观看| 精品国产91亚洲一区二区三区www 精品国产_亚洲人成在线 | 久久久精品久久久| 嫩草国产精品入口| 污视频网站观看| 婷婷开心激情综合| 蜜芽在线免费观看| 快播日韩欧美| 国产aⅴ精品一区二区三区色成熟| 香蕉影院在线观看| 欧美高清无遮挡|