自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Python數(shù)據(jù)結(jié)構(gòu)之單鏈表

開發(fā) 后端
單向鏈表(單鏈表)是鏈表的一種,其特點是鏈表的鏈接方向是單向的,對鏈表的訪問要通過順序讀取從頭部開始。單鏈表是一種鏈?zhǔn)酱嫒〉臄?shù)據(jù)結(jié)構(gòu),用一組地址任意的存儲單元存放線性表中的數(shù)據(jù)元素。

[[410894]]

本文轉(zhuǎn)載自微信公眾號「python與大數(shù)據(jù)分析」,作者一只小小鳥鳥。轉(zhuǎn)載本文請聯(lián)系python與大數(shù)據(jù)分析公眾號。

今天終于把大學(xué)都沒想明白的鏈表數(shù)據(jù)結(jié)構(gòu)整明白了,也算小小的收獲,挺好玩的。文后附鏈表操作示意圖。

單向鏈表(單鏈表)是鏈表的一種,其特點是鏈表的鏈接方向是單向的,對鏈表的訪問要通過順序讀取從頭部開始。單鏈表是一種鏈?zhǔn)酱嫒〉臄?shù)據(jù)結(jié)構(gòu),用一組地址任意的存儲單元存放線性表中的數(shù)據(jù)元素。

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

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

代碼基本為原創(chuàng),經(jīng)過大量重寫

  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.         # 新節(jié)點的鏈接指向頭節(jié)點 
  31.         node.next=self.header 
  32.         # 鏈表的頭指向新節(jié)點 
  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() 

結(jié)果如下

  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 

鏈表頭部增加節(jié)點示意圖

從鏈表尾部增加節(jié)點示意圖

 

責(zé)任編輯:武曉燕 來源: python與大數(shù)據(jù)分析
相關(guān)推薦

2012-02-02 10:21:05

單鏈表nexthead

2021-07-15 06:43:12

Python數(shù)據(jù)結(jié)構(gòu)

2017-03-01 13:58:46

Python數(shù)據(jù)結(jié)構(gòu)鏈表

2021-03-10 08:42:19

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-08-03 10:24:59

數(shù)據(jù)跳躍鏈表結(jié)構(gòu)

2021-05-12 14:09:35

鏈表數(shù)據(jù)結(jié)構(gòu)線性結(jié)構(gòu)

2021-04-12 15:47:00

數(shù)據(jù)結(jié)構(gòu)算法鏈表

2021-07-16 07:57:34

Python數(shù)據(jù)結(jié)構(gòu)

2021-12-21 08:19:29

數(shù)據(jù)結(jié)構(gòu)算法鏈表相交

2020-10-28 10:10:03

Java單鏈表數(shù)據(jù)結(jié)構(gòu)

2021-10-29 11:27:52

鏈表數(shù)據(jù)結(jié)構(gòu)算法

2021-01-06 08:03:00

JavaScript數(shù)據(jù)結(jié)構(gòu)

2021-07-11 12:06:43

python數(shù)據(jù)結(jié)構(gòu)

2021-01-28 07:33:34

JavaScript鏈表數(shù)據(jù)

2023-03-28 07:44:23

數(shù)據(jù)結(jié)構(gòu)數(shù)組

2023-10-06 20:21:28

Python鏈表

2009-07-02 14:59:28

Java考研試題

2018-06-06 08:54:23

數(shù)據(jù)結(jié)構(gòu)存儲

2024-10-11 16:43:05

高并發(fā)數(shù)據(jù)結(jié)構(gòu)技巧

2023-09-21 16:13:20

Python數(shù)據(jù)結(jié)構(gòu)
點贊
收藏

51CTO技術(shù)棧公眾號