Python代碼實(shí)現(xiàn)雙鏈表
本文實(shí)例為大家分享了Python代碼實(shí)現(xiàn)雙鏈表的具體代碼,供大家參考,具體內(nèi)容如下
雙鏈表的每個(gè)節(jié)點(diǎn)有兩個(gè)指針: 一個(gè)指向后一個(gè)節(jié)點(diǎn),另一個(gè)指向前一個(gè)節(jié)點(diǎn)
class Node(object): ?? ?def __init__(self, item=None): ?? ??? ?#放數(shù)據(jù) ?? ??? ?self.item= item ?? ??? ?#指向后一個(gè)節(jié)點(diǎn) ?? ??? ?self.next = None ?? ??? ?#指向前一個(gè)節(jié)點(diǎn) ?? ??? ?self.prior =None
此時(shí)當(dāng)前鏈表第一個(gè)節(jié)點(diǎn)就是頭節(jié)點(diǎn)指向的節(jié)點(diǎn) 20就是第一個(gè)節(jié)點(diǎn) 下圖
node.next = self.head 當(dāng)前節(jié)點(diǎn)指向原第一個(gè)節(jié)點(diǎn)
頭插法


如何插入呢



插入
p.next = curNode.next #指向后一個(gè)節(jié)點(diǎn)
curNode.next.prior = p #指向前一個(gè)節(jié)點(diǎn)

刪除

雙鏈表刪除

考慮特殊情況刪除的

正常刪除

雙鏈表刪除 30

#雙鏈表頭插法

#停在前一個(gè)位置了
count < (pos -1 )
#雙向鏈表 ?從左往右讀
class Node(object):
? ? ? ? """雙向鏈表節(jié)點(diǎn)"""
? ? ? ? def __init__(self,item):
? ? ? ? ? ? ? ? #放數(shù)據(jù)的節(jié)點(diǎn)
? ? ? ? ? ? ? ? self.elem = item
? ? ? ? ? ? ? ? #指向后一個(gè)節(jié)點(diǎn)
? ? ? ? ? ? ? ? self.next = None
? ? ? ? ? ? ? ? #指向前一個(gè)節(jié)點(diǎn)
? ? ? ? ? ? ? ? self.prev = None
#雙向鏈表
class LinkList(object):
? ? ? ? def __init__(self,node=None):
? ? ? ? ? ? ? ? #代表頭節(jié)點(diǎn)
? ? ? ? ? ? ? ? self.__head = node
? ? ? ? #判斷鏈表是否為空
? ? ? ? def is_empty(self):
? ? ? ? ? ? ? ? return self.__head == None
? ? ? ? def length(self):
? ? ? ? ? ? ? ? """返回鏈表的長(zhǎng)度"""
? ? ? ? ? ? ? ? #cur游標(biāo)移動(dòng),從而實(shí)現(xiàn)遍歷元素的功能
? ? ? ? ? ? ? ? cur = self.__head
? ? ? ? ? ? ? ? #count用來(lái)計(jì)數(shù)
? ? ? ? ? ? ? ? count = 0
? ? ? ? ? ? ? ? while cur != None:
? ? ? ? ? ? ? ? ? ? ? ? count += 1
? ? ? ? ? ? ? ? ? ? ? ? #讓cur游標(biāo)可以向下移動(dòng)
? ? ? ? ? ? ? ? ? ? ? ? cur = cur.next
? ? ? ? ? ? ? ? return count
? ? ? ? #遍歷整個(gè)鏈表
? ? ? ? def travel(self):
? ? ? ? ? ? ? ? if self.is_empty():
? ? ? ? ? ? ? ? ? ? ? ? return
? ? ? ? ? ? ? ? #建立游標(biāo)等于起始節(jié)點(diǎn)
? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ? ? ? ? cur = self.__head
? ? ? ? ? ? ? ? ? ? ? ? while cur != None:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? print(cur.elem,end=" ")
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cur = cur.next
? ? ? ? ? ? ? ? ? ? ? ? print("")
? ? ? ? #頭插法
? ? ? ? def add(self,item):
? ? ? ? ? ? ? ? #新節(jié)點(diǎn)
? ? ? ? ? ? ? ? node = Node(item)
? ? ? ? ? ? ? ? if self.is_empty():
? ? ? ? ? ? ? ? ? ? ? ? #頭節(jié)點(diǎn)指向了新的節(jié)點(diǎn)
? ? ? ? ? ? ? ? ? ? ? ? self.__head = node
? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ? ? ? ? #新節(jié)點(diǎn)指向原第一個(gè)節(jié)點(diǎn)
? ? ? ? ? ? ? ? ? ? ? ? node.next = self.__head
? ? ? ? ? ? ? ? ? ? ? ? self.__head = node
? ? ? ? ? ? ? ? ? ? ? ? node.next.prev = node
? ? ? ? def append(self,item):
? ? ? ? ? ? ? ? """鏈表尾部添加元素"""
? ? ? ? ? ? ? ? node = Node(item) ?#定義新節(jié)點(diǎn)
? ? ? ? ? ? ? ? #鏈表是否為空鏈表
? ? ? ? ? ? ? ? if self.is_empty():
? ? ? ? ? ? ? ? ? ? ? ? #如果為空,新的節(jié)點(diǎn)加了進(jìn)去
? ? ? ? ? ? ? ? ? ? ? ? self.__head = node
? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ? ? ? ? #頭節(jié)點(diǎn) 創(chuàng)建游標(biāo)
? ? ? ? ? ? ? ? ? ? ? ? cur = self.__head ? #設(shè)置指向頭結(jié)點(diǎn)的游標(biāo) ?此時(shí)的當(dāng)前鏈表第一個(gè)節(jié)點(diǎn),就是頭節(jié)點(diǎn)指向的節(jié)點(diǎn)
? ? ? ? ? ? ? ? ? ? ? ? #cur到最后一個(gè)節(jié)點(diǎn)停下
? ? ? ? ? ? ? ? ? ? ? ? while cur.next != None:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cur = cur.next
? ? ? ? ? ? ? ? ? ? ? ? #添加節(jié)點(diǎn)到尾部 cur道了最后一個(gè)結(jié)點(diǎn) ?cur.next指向了新的節(jié)點(diǎn)node ?從左往右讀 ?
? ? ? ? ? ? ? ? ? ? ? ? cur.next = node
? ? ? ? ? ? ? ? ? ? ? ? #當(dāng)前的節(jié)點(diǎn)指向它前一個(gè)
? ? ? ? ? ? ? ? ? ? ? ? node.prev = cur
? ? ? ? #插入法 ?#pos從零開(kāi)始
? ? ? ? def insert(self,pos,item):
? ? ? ? ? ? ? ? """在指定位置添加元素"""
? ? ? ? ? ? ? ? #指向不是頭部元素,self.__head的地址
? ? ? ? ? ? ? ? # 為下一個(gè)元素,所以pre為下一個(gè)元素
? ? ? ? ? ? ? ? if pos <= 0:
? ? ? ? ? ? ? ? ? ? ? ? #認(rèn)為是頭插法
? ? ? ? ? ? ? ? ? ? ? ? self.add(item)
? ? ? ? ? ? ? ? #假如長(zhǎng)度是3 pos大于2要特殊處理 ?
? ? ? ? ? ? ? ? elif pos > (self.length()-1):
? ? ? ? ? ? ? ? ? ? ? ? #尾插法
? ? ? ? ? ? ? ? ? ? ? ? self.append(item)
? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ?? ??? ?#創(chuàng)建節(jié)點(diǎn) 新節(jié)點(diǎn)
? ? ? ? ? ? ? ? ? ? ? ? node = Node(item)
? ? ? ? ? ? ? ? ? ? ? ? cur = self.__head
? ? ? ? ? ? ? ? ? ? ? ? count = 0
? ? ? ? ? ? ? ? ? ? ? ? #動(dòng)起來(lái)
? ? ? ? ? ? ? ? ? ? ? ? while count < pos:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? count+=1
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cur = cur.next
? ? ? ? ? ? ? ? ? ? ? ?
? ? ? ? ? ? ? ? ? ? ? ? #把節(jié)點(diǎn)鏈接到中間任意位置 插入前一個(gè)節(jié)點(diǎn) ? 此時(shí),cur停在后一個(gè)節(jié)點(diǎn)
? ? ? ? ? ? ? ? ? ? ? ? node.next = cur
? ? ? ? ? ? ? ? ? ? ? ? node.prev = cur.prev
? ? ? ? ? ? ? ? ? ? ? ? cur.prev.next = node
? ? ? ? ? ? ? ? ? ? ? ? cur.prev = node
? ? ? ? def remove(self,item):
? ? ? ? ? ? ? ? """刪除元素"""
? ? ? ? ? ? ? ? if self.is_empty():
? ? ? ? ? ? ? ? ?? ?return
? ? ? ? ? ? ? ? cur = self.__head
? ? ? ? ? ? ? ? #查找所有的位置有沒(méi)有要?jiǎng)h除的,若有則刪除
? ? ? ? ? ? ? ? while cur != None:
? ? ? ? ? ? ? ? ?? ??? ?#判斷cur指向的數(shù)據(jù),是否為要?jiǎng)h除的數(shù)據(jù) ? item要?jiǎng)h除的元素
? ? ? ? ? ? ? ? ? ? ? ? if cur.elem == item:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #判斷此節(jié)點(diǎn)是否為頭節(jié)點(diǎn)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #考慮特殊情況,恰好要?jiǎng)h除是第一個(gè)元素 ? ?當(dāng)前的元素就是我要?jiǎng)h除的元素?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if cur == self.__head:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #如果刪除中間, ?頭節(jié)點(diǎn)指向后一個(gè)節(jié)點(diǎn)?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? self.__head = cur.next
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #考慮鏈表只有一個(gè)節(jié)點(diǎn) ?直接指向None
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if cur.next != None:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #是否只有一個(gè)節(jié)點(diǎn)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cur.next.prev = None
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #中間節(jié)點(diǎn)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cur.prev.next = cur.next
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if cur.next != None:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cur.next.prev = cur.prev
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? break
? ? ? ? ? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #沒(méi)有找到,cur游標(biāo)向繼續(xù)往下移動(dòng)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cur = cur.next
? ? ? ? def search(self,item):
? ? ? ? ? ? ? ? """查找結(jié)點(diǎn)是否存在"""
? ? ? ? ? ? ? ? #如果是一個(gè)空鏈表
? ? ? ? ? ? ? ? if self.is_empty():
? ? ? ? ? ? ? ? ? ? ? ? return False
? ? ? ? ? ? ? ? cur = self.__head
? ? ? ? ? ? ? ? while cur.next != self.__head:
? ? ? ? ? ? ? ? ? ? ? ? #cur數(shù)據(jù)是否為查找的數(shù)據(jù) item是要查的數(shù)據(jù)?
? ? ? ? ? ? ? ? ? ? ? ? if cur.elem == item:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? return True
? ? ? ? ? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cur = cur.next
? ? ? ? ? ? ? ? #遍歷完成 cur指向None
? ? ? ? ? ? ? ? return False
if __name__ == '__main__':
? ? ? ? ll = LinkList()
? ? ? ? #第一次的
? ? ? ? print(ll.is_empty())
? ? ? ? print(ll.length())
? ? ? ? ll.append(1)
? ? ? ? print(ll.is_empty())
? ? ? ? print(ll.length())
? ? ? ? ll.append(2)
? ? ? ? ll.append(3)
? ? ? ? ll.append(4)
? ? ? ? ll.append(5)
? ? ? ? ll.travel()
? ? ? ? ll.insert(-1,50)
? ? ? ? ll.travel()
? ? ? ? ll.insert(2,60)
? ? ? ? ll.travel()
? ? ? ? ll.insert(10,300)
? ? ? ? ll.travel()
? ? ? ? ll.remove(50)
? ? ? ? ll.travel()
? ? ? ? ll.remove(300)
? ? ? ? ll.travel()
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python雙向鏈表實(shí)現(xiàn)實(shí)例代碼
- Python單向鏈表和雙向鏈表原理與用法實(shí)例詳解
- Python二叉搜索樹(shù)與雙向鏈表轉(zhuǎn)換實(shí)現(xiàn)方法
- Python編程實(shí)現(xiàn)雙鏈表,棧,隊(duì)列及二叉樹(shù)的方法示例
- Python二叉搜索樹(shù)與雙向鏈表轉(zhuǎn)換算法示例
- Python數(shù)據(jù)結(jié)構(gòu)之雙向鏈表的定義與使用方法示例
- Python雙向循環(huán)鏈表實(shí)現(xiàn)方法分析
- python雙向鏈表原理與實(shí)現(xiàn)方法詳解
- Python雙鏈表原理與實(shí)現(xiàn)方法詳解
- Python數(shù)據(jù)結(jié)構(gòu)之雙向鏈表詳解
相關(guān)文章
基于python的漢字轉(zhuǎn)GBK碼實(shí)現(xiàn)代碼
今天想用python調(diào)用百度框計(jì)算的搜過(guò)結(jié)果,看到了URL里面的漢字用GBK編碼,雖然可以直接在URL里面加入中文,之前也做過(guò)一個(gè)簡(jiǎn)體字轉(zhuǎn)GBK碼的python函數(shù),但還是略嫌麻煩,今天改了一下2012-02-02
Python實(shí)戰(zhàn)項(xiàng)目用PyQt5制作漫畫(huà)臉GUI界面
PyQt5 是用來(lái)創(chuàng)建Python GUI應(yīng)用程序的工具包。作為一個(gè)跨平臺(tái)的工具包,PyQt可以在所有主流操作系統(tǒng)上運(yùn)行,本文主要介紹了如何用PyQt5制作漫畫(huà)臉的GUI界面2021-10-10
Python實(shí)現(xiàn)階乘的四種寫(xiě)法
本文主要介紹了Python實(shí)現(xiàn)階乘的六種寫(xiě)法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-01-01
淺析AST抽象語(yǔ)法樹(shù)及Python代碼實(shí)現(xiàn)
Abstract Syntax Tree抽象語(yǔ)法樹(shù)簡(jiǎn)寫(xiě)為ATS,是相當(dāng)于用樹(shù)結(jié)構(gòu)將代碼程式表現(xiàn)出來(lái)的一種數(shù)據(jù)結(jié)構(gòu),這里我們就來(lái)淺析AST抽象語(yǔ)法樹(shù)及Python代碼實(shí)現(xiàn)2016-06-06
python 利用 PIL 將數(shù)組值轉(zhuǎn)成圖片的實(shí)現(xiàn)
這篇文章主要介紹了python 利用 PIL 將數(shù)組值轉(zhuǎn)成圖片的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
Python+樹(shù)莓派+YOLO打造一款人工智能照相機(jī)
今天,我們將自己動(dòng)手打造出一款基于深度學(xué)習(xí)的照相機(jī),當(dāng)小鳥(niǎo)出現(xiàn)在攝像頭畫(huà)面中時(shí),它將能檢測(cè)到小鳥(niǎo)并自動(dòng)進(jìn)行拍照2018-01-01

