精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

一区在线免费| 9999在线精品视频| 久久久精品日韩欧美| 国产精品视频一区二区高潮| 少妇人妻丰满做爰xxx| 国产精品国产| 欧美日韩一区二区三区免费看| 最新国产精品久久| 亚洲欧美日韩成人在线| 蜜臀av性久久久久蜜臀av麻豆| 欧美成年人视频网站欧美| 欧洲一级黄色片| 4438五月综合| 欧美日韩亚洲一区二区| 在线观看日韩羞羞视频| 亚洲色图21p| 青青草国产精品亚洲专区无| 九九精品在线播放| 免费成人深夜天涯网站| 女同另类激情重口| 91精品国产91综合久久蜜臀| 欧美 日韩 国产一区| 菠萝菠萝蜜在线视频免费观看| 91美女片黄在线观看| 亚洲综合在线播放| 亚洲 小说区 图片区| 亚洲毛片视频| 久久伊人免费视频| 亚洲性猛交xxxx乱大交| 97se亚洲| 欧美一区三区二区| av在线无限看| 无遮挡爽大片在线观看视频| 亚洲男人的天堂网| 亚洲精品人成| 九色视频在线播放| 99亚偷拍自图区亚洲| 91国产在线免费观看| 伊人免费在线观看高清版| 国产欧美短视频| 欧美精品福利在线| 紧身裙女教师波多野结衣| 日韩av二区| 国产亚洲xxx| 中文字幕丰满乱子伦无码专区| 6080成人| 日韩欧美激情四射| 丰满人妻一区二区三区大胸| 亚洲精品66| 欧美日本一道本在线视频| av免费中文字幕| 蜜桃视频在线观看免费视频| 五月天久久比比资源色| 日韩一区二区高清视频| 青春草在线免费视频| 国产精品传媒视频| 中文精品一区二区三区| 午夜视频在线观看网站| 国产精品萝li| 欧美日韩在线免费观看视频| 日本天堂在线观看| 亚洲欧洲中文日韩久久av乱码| 在线电影看在线一区二区三区| 在线观看免费黄视频| 国产精品护士白丝一区av| 午夜精品区一区二区三| av大全在线免费看| 18成人在线视频| 九一免费在线观看| 国产天堂在线播放视频| 欧美日韩加勒比精品一区| 日本精品一区在线观看| 久久久成人av毛片免费观看| 欧美日韩高清在线播放| 奇米777在线视频| 97久久精品| 精品丝袜一区二区三区| 在线看片中文字幕| 亚洲影视一区二区三区| 久久久噜久噜久久综合| 91美女免费看| 蜜臀av性久久久久蜜臀av麻豆| 成人有码在线播放| 丰满少妇一级片| wwwwww.欧美系列| 蜜桃导航-精品导航| 在线视频1区2区| 一区av在线播放| av免费观看网| 国产欧美在线观看免费| 欧美成人官网二区| 最近中文字幕在线mv视频在线| 欧美超碰在线| 欧美激情视频一区二区三区不卡| 在线观看免费国产视频| 捆绑紧缚一区二区三区视频| 99re国产在线播放| 国内精品一区视频| 亚洲美腿欧美偷拍| 欧美国产激情视频| 成人短视频软件网站大全app| 日韩三级视频中文字幕| 久久精品一区二区免费播放 | 黄色国产在线播放| 欧美精品三级| 国产97在线观看| 性一交一乱一精一晶| 久久久精品国产免大香伊| 欧洲金发美女大战黑人| 波多野结衣亚洲| 日韩一区二区在线看| 国产熟妇久久777777| 中文字幕亚洲精品乱码| 国产成人在线视频| 熟妇人妻av无码一区二区三区| 亚洲国产高清在线观看视频| 欧美不卡在线播放| vam成人资源在线观看| 精品视频www| 久久精品www| 久久av中文字幕片| 日韩亚洲一区在线播放| 国内激情视频在线观看| 欧美一区二区日韩一区二区| 微拍福利一区二区| 国产精品久久久久9999高清| av免费观看久久| 在线观看完整版免费| 色婷婷国产精品| 黄色激情在线观看| 中文字幕亚洲精品乱码| 国产日韩欧美夫妻视频在线观看 | 国产一区二区三区高清在线观看| 久久久无码精品亚洲国产| 麻豆精品视频在线| 视频一区在线免费观看| 一个人看的www视频在线免费观看| 欧美va亚洲va| 三上悠亚作品在线观看| 奇米精品一区二区三区在线观看 | 在线观看视频一区二区欧美日韩| 国产免费无码一区二区| 91精品国产91久久久久久黑人| 国产精品扒开腿爽爽爽视频 | 26uuu色噜噜精品一区| 免费高清一区二区三区| 欧美日韩黄色| 久久综合免费视频| 国产普通话bbwbbwbbw| 日韩一区中文字幕| 亚洲综合20p| 欧美电影三区| 成人激情视频在线| 黄色网址视频在线观看| 国产视频不卡在线| av在线下载| 欧美日韩国产一区二区三区地区| 在线观看国产精品一区| 日韩高清一区在线| 日本在线免费观看一区| 激情开心成人网| 精品视频一区在线视频| av在线无限看| 久蕉在线视频| 亚洲国产精品欧美一二99| zjzjzjzjzj亚洲女人| 今天的高清视频免费播放成人| 国产精品12| yellow在线观看网址| 亚洲国产成人精品一区二区| 国产无遮挡呻吟娇喘视频| 久久蜜桃av一区精品变态类天堂| 日本成年人网址| 精品久久不卡| 成人淫片在线看| 国产探花视频在线观看| 亚洲精选在线观看| 亚洲一卡二卡在线| 亚洲精品免费播放| 中文字幕a在线观看| 欧美一级二区| 亚洲一区二区在线免费观看| 国产麻豆一区二区三区| 欧美激情视频网站| 国产二区在线播放| 6080午夜不卡| 99热国产在线观看| 亚洲国产精品精华液ab| 18深夜在线观看免费视频| 日韩视频精品在线观看| 亚洲精品视频一二三| 一区二区在线视频观看| 国产成人精品免费久久久久 | 欧美激情18p| 深夜福利在线观看直播| 欧美精品色一区二区三区| 国产亚洲精品女人久久久久久| 91日韩在线专区| av中文字幕网址| aa国产精品| 国产免费色视频| 欧美日韩一区二区三区四区不卡| 国产精品专区第二| 韩国成人二区| 精品中文字幕视频| a黄色在线观看| 精品久久久久久久久久久院品网 | 老司机精品视频一区二区三区| 精品国偷自产一区二区三区| 精品色999| 国产精品久久久久久久久婷婷| 国模视频一区| 国语自产精品视频在线看| 99精品老司机免费视频| 日韩成人在线网站| 精品国产18久久久久久| 欧美性做爰猛烈叫床潮| 国产大片aaa| 亚洲视频免费看| 欧美一区二区三区粗大| 97se亚洲国产综合自在线不卡 | 972aa.com艺术欧美| 成人不卡免费视频| 丝袜亚洲精品中文字幕一区| 精品久久久久久无码中文野结衣| 欧美xxav| 午夜欧美性电影| 久久综合色占| 蜜桃视频日韩| 少妇高潮一区二区三区| 成人欧美一区二区三区在线观看 | 欧美一区二区成人| 亚洲无码久久久久| 欧美午夜一区二区三区| 一本一道无码中文字幕精品热| 一区二区三区欧美激情| 国产乱子轮xxx农村| 欧美—级在线免费片| 91精品人妻一区二区| 成人动漫视频在线| 午夜福利三级理论电影| 国产精品原创巨作av| 在线免费看污网站| 狠狠色丁香久久婷婷综| 天天干天天玩天天操| 免费久久99精品国产| 色综合天天色综合| 免费在线成人网| 国产三级国产精品国产专区50| 日韩综合一区二区| 精品久久久久av| 日日骚欧美日韩| 北条麻妃av高潮尖叫在线观看| 久久av一区二区三区| 欧美成人免费高清视频| 免费国产自线拍一欧美视频| 日本黄网站免费| 日韩激情一区二区| 牛夜精品久久久久久久| 韩日精品视频一区| aaaaa黄色片| k8久久久一区二区三区| 你懂的在线观看网站| 久久人人97超碰com| 国产精品密蕾丝袜| 国产精品―色哟哟| 欧美日韩在线视频免费| 亚洲亚洲人成综合网络| 久久久国产高清| 欧美亚洲国产一区二区三区va| 国产一区二区自拍视频| 日韩视频免费观看高清完整版在线观看 | 欧美日韩亚洲一区二区三区在线观看| 国产99精品| 爱爱爱视频网站| 亚洲特色特黄| 毛片一区二区三区四区| 久久99国产精品成人| 午夜性福利视频| www国产精品av| 免费黄色国产视频| 亚洲一区二区在线免费观看视频 | 久久久水蜜桃| 不卡中文一二三区| 欧美日韩激情四射| 久久狠狠婷婷| 人妻巨大乳一二三区| av中文字幕亚洲| 永久免费观看片现看| 一区二区三区蜜桃| 日韩国产亚洲欧美| 欧美一级国产精品| 日本在线视频1区| 久久天天躁狠狠躁夜夜爽蜜月| av中文在线资源库| 国产伦精品免费视频| 另类春色校园亚洲| 伊人久久大香线蕉成人综合网 | 最近中文字幕一区二区三区| 久草国产在线视频| 欧美视频一区二区三区四区 | 久久久久国产一区二区三区四区 | 精品久久中文字幕久久av| 中文字幕人妻色偷偷久久| 欧美va亚洲va| 麻豆免费在线视频| 欧美一区二区三区免费观看| 国产va免费精品观看精品| 欧美精品亚洲| 精品9999| 韩国一区二区在线播放| 久久精品亚洲精品国产欧美| 精品少妇theporn| 欧美日本韩国一区| 韩国三级av在线免费观看| 久久久久久久成人| 国产一区二区三区亚洲综合| 日韩欧美在线电影| 亚洲欧美网站| 色多多视频在线观看| 香蕉成人伊视频在线观看| 麻豆成人免费视频| 精品国产一区久久| 五月香视频在线观看| 热久久免费视频精品| 国产精品网在线观看| 精品一区二区三区毛片| 美女www一区二区| 国产美女精品久久| 午夜精品一区在线观看| 国产高潮流白浆喷水视频| 色哟哟网站入口亚洲精品| av日韩亚洲| 精品麻豆av| 在线成人亚洲| 国产艳妇疯狂做爰视频| 亚洲你懂的在线视频| 国产乱码精品一区二区| 伊人久久五月天| 高清av一区二区三区| 欧美日本国产精品| 亚洲欧美视频| 3d动漫精品啪啪一区二区下载| 精品福利在线视频| 亚洲av片在线观看| 日本精品一区二区三区在线播放视频 | 亚洲第一主播视频| 免费av网站在线播放| 久久久久久久成人| 任你弄精品视频免费观看| 国产 日韩 欧美在线| 91在线视频18| 波多野结衣小视频| 中文字幕一精品亚洲无线一区| 国产极品一区| 欧美aaa在线观看| 国产麻豆午夜三级精品| 久久精品这里只有精品| 亚洲成年人在线| 免费一二一二在线视频| 美日韩免费视频| 日韩电影在线观看电影| 亚洲欧美精品久久| 欧美一级精品在线| 男女免费观看在线爽爽爽视频| 国产一区二区三区四区五区在线| 99视频精品| 中字幕一区二区三区乱码| 欧美日韩三级在线| 成人在线网址| 国产日韩亚洲精品| 久久最新视频| 欧美性生交大片| 日韩欧美国产一区在线观看| a'aaa级片在线观看| 日本高清不卡三区| 狠狠色丁香九九婷婷综合五月| 久久久久成人精品无码| 日韩av网站在线| 久久xxx视频| 欧美人与动牲交xxxxbbbb| 91女人视频在线观看| 一卡二卡在线观看| 久久久久久国产| 欧洲杯什么时候开赛| 亚洲午夜精品在线观看| 欧美视频在线免费| 久久bbxx| 欧美精品尤物在线| 国产盗摄视频一区二区三区| av黄色在线播放| 久久久国产在线视频| 日日天天久久| 天天干天天色天天干| 午夜天堂影视香蕉久久| 日韩成人影视| 久草热久草热线频97精品| 精品一区二区三区久久久| 免费在线不卡视频| 欧美成人久久久|