




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第Python實現(xiàn)雙向鏈表基本操作雙向鏈表的基本操作的實現(xiàn),供大家參考,具體內(nèi)容如下
在之前的博客中介紹了三種鏈表,分別是單鏈表、單向循環(huán)鏈表以及雙向鏈表。本篇博客將用Python來實現(xiàn)雙向鏈表的如下操作。(用到的工具是Python3)
is_empty():判斷鏈表是否為空
length():返回鏈表的長度
travel():遍歷
add(item):在頭部添加一個節(jié)點
append(item):在尾部添加一個節(jié)點
insert(pos,item):在指定位置pos添加一個節(jié)點
remove(item):刪除一個節(jié)點
search(item):查找節(jié)點是否存在
Python實現(xiàn)
classNode(object):
'''雙向鏈表節(jié)點'''
def__init__(self,item):
self.item=item
self.next=None
self.prev=None
classDoubleLink(object):
'''雙向鏈表'''
def__init__(self):
self._head=None
defis_empty(self):
'''判斷是否為空'''
returnself._head==None
deflength(self):
'''返回鏈表的長度'''
cur=self._head
count=0
whilecur!=None:
count+=1
cur=cur.next
returncount
deftravel(self):
'''遍歷鏈表'''
cur=self._head
whilecur!=None:
print(cur.item)
cur=cur.next
print("")
defadd(self,item):
'''頭部插入元素'''
node=Node(item)
ifself.is_empty():
#如果是空鏈表,將_head指向None
self._head=node
else:
#將node的next指向_head的頭節(jié)點
node.next=self._head
#將_head的頭節(jié)點的prev指向node
self._head.prev=node
#將_head指向node
self._head=node
defappend(self,item):
'''尾部插入元素'''
node=Node(item)
ifself.is_empty():
self._head=node
else:
#移動到鏈表尾部
cur=self._head
whilecur.next!=None:
cur=cur.next
#將尾結(jié)點cur的next指向node
cur.next=node
#將node的prev指向cur
node.prev=cur
defsearch(self,item):
'''查找元素是否存在'''
cur=self._head
whilecur!=None:
ifcur.item==item:
returnTrue
cur=cur.next
returnFalse
指定位置插入節(jié)點
在該操作中,要注意鏈的指向的先后順序。
definsert(self,pos,item):
'''在指定位置添加節(jié)點'''
ifpos=0:
self.add(item)
elifpos(self.length()-1):
self.append(item)
else:
node=Node()
cur=self._head()
count=0
#移動到指定的前一個位置
whilecurpos-1:
count+=1
cur=cur.next
#將node的prev指向cur
node.prev=cur
#將node的next指向cur的下一個節(jié)點
node.next=cur.next
#將cur的下一個節(jié)點的prev指向node
cur.next.prev=node
#將cur.next指向node
cur.next=node
刪除元素
defremove(self,item):
'''刪除元素'''
ifself.is_empty():return
else:
cur=self._head
ifcur.item==item:
#如果首節(jié)點的元素是要刪除的元素
ifcur.next==None:
#如果鏈表中只有一個節(jié)點
self._head=None
else:
cur.next.prev=None
self._head=cur.next
return
whilecur!=None:
ifcur.item==item:
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- T/CSPSTC 25-2019硅基薄膜光伏組件光致衰減測試方法
- T/CSPCI 00001-2022汽油中苯胺類化合物的分離和測定固相萃取/氣相色譜-質(zhì)譜法
- T/CQAP 3006-2023大興安嶺地產(chǎn)中藥材返魂草質(zhì)量規(guī)范
- T/CNLIC 0080-2023 T/CNFA 018-2023綠色設(shè)計產(chǎn)品評價技術(shù)規(guī)范軟體家具
- T/CNCA 018-2022基于動態(tài)地質(zhì)模型與自主規(guī)劃開采的綜采工作面驗收規(guī)范
- T/CMA HG021-2020輪胎試驗路面構(gòu)造深度測量方法手工鋪砂法
- T/CIES 030-2020中小學(xué)教室健康照明設(shè)計規(guī)范
- T/CIE 165-2023企業(yè)級固態(tài)硬盤測試規(guī)范第1部分:功能測試
- T/CI 294-2024重大固定資產(chǎn)投資項目社會穩(wěn)定風(fēng)險評估分析篇章和評估報告編寫規(guī)范
- 【正版授權(quán)】 ISO 834-1:2025 EN Fire-resistance tests - Elements of building construction - Part 1: General requirements
- 基于主題意義的小學(xué)英語單元整體教學(xué) 論文
- 中山職業(yè)技術(shù)學(xué)院宿舍寬帶接入校園網(wǎng)連接技術(shù)方案
- 陶行知教育名篇讀書分享ppt
- 癌性傷口的處理教學(xué)課件
- 血栓與止血檢驗及其相關(guān)疾病-血栓與止血檢驗(血液學(xué)檢驗課件)
- 深圳中考志愿表格模板
- 村衛(wèi)生室醫(yī)保自查自糾報告及整改措施
- 【電氣專業(yè)】15D501建筑物防雷設(shè)施安裝
- 中國傳統(tǒng)文化知到章節(jié)答案智慧樹2023年西安理工大學(xué)
- 新疆維吾爾自治區(qū)初中學(xué)業(yè)水平考試英語答題卡
- 四位數(shù)乘四位數(shù)乘法題500道
評論
0/150
提交評論