文章目录
双向链表
格式
构建双向链表
#coding:utf-8
class Node(object):
'''节点'''
def __init__(self,item):
self.elem=item
self.next=None
self.prev=None
class DoubleLinkList(object):
'''双链表'''
def __init__(self,node=None):
self.__head=node
判断链表是否为空(与单链表同)
def is_empty(self):
'''链表是否为空'''
return self.__head is None
链表长度
def length(self):
'''链表长度'''
# cur游标,用来移动遍历节点
cur = self.__head
# count记录数量
count = 0#一定要设置为0,满足空链表特殊情况
while cur != None:
count += 1
cur = cur.next
return count
遍历
def travel(self):
'''遍历整个列表'''
cur=self.__head
while cur!=None:
print(cur.elem,end=" ")
cur=cur.next
print()
添加元素:头插法
def add(self,item):
'''链表头部添加元素,头插法'''
node=Node(item)
node.next=self.__head
self.__head.prev=node
self.__head=node #"="右边是被指向的
#或先self.__head=node,再node.next.prev=node
添加元素:尾插法
def append(self,item):
'''链表尾部添加元素,尾插法'''
node=Node(item)
if self.is_empty():
self.__head=node
else:
cur = self.__head
while cur.next != None:
cur = cur.next
cur.next = node
node.prev=cur
添加元素:指定位置
def insert(self,pos,item):
'''指定位置添加元素
pos从0开始索引'''
if pos<=0:
self.add(item)
elif pos>(self.length()-1):
self.append(item)
else:
cur = self.__head
count = 0
while count < (pos-1):
count += 1
cur = cur.next
# 当循环退出后,pre指向pos-1位置
node = Node(item)
node.next = cur
node.prev = cur.prev
cur.prev.next=node
cur.prev=node
删除节点
def remove(self,item):
'''删除节点'''
cur=self.__head
while cur!=None:
if cur.elem==item:
#先判断此节点是否是头节点
#头节点
if cur==self.__head:
self.__head=cur.next
if cur.next:
#判断链表是否只有一个节点
cur.next.prev = None
else:
cur.prev.next=cur.next
if cur.next:
cur.next.prev = cur.prev
break
else:
cur=cur.next
查找节点是否存在
def search(self,item):
'''查找节点是否存在'''
cur=self.__head
while cur !=None:
if cur.elem == item:
return True
else:
cur = cur.next
return False
单向循环链表
单链表的一个变形是单向循环链表,链表中最后一个节点的next域不再为None,而是指向链表的头节点。
构建单向循环链表
#coding:utf-8
class Node(object):
'''节点'''
def __init__(self,elem):
self.elem = elem
self.next = None
class SingleCycleLinkList(object):
'''单向循环链表'''
def __init__(self,node=None):
self.__head=node
if node:
node.next = node
判断链表是否为空
def is_empty(self):
'''链表是否为空'''
return self.__head==None
链表长度
def length(self):
'''链表长度'''
if self.is_empty():
return 0
# cur游标,用来移动遍历节点
cur = self.__head
# count记录数量
count = 1 #count从1开始,因为不像单链表一样判断cur在None停;而是cur.next
while cur.next!= self.__head:
count += 1
cur = cur.next
return count
遍历整个列表
def travel(self):
'''遍历整个列表'''
if self.is_empty():
return
cur=self.__head
while cur.next!=self.__head:
print(cur.elem,end=" ")
cur=cur.next
#退出循环,cur指向尾节点,但尾节点的元素未打印,下一句代码打印
print(cur.elem)
添加元素:头插法
def add(self,item):
'''链表头部添加元素,头插法'''
node=Node(item)
if self.is_empty():
self.__head=node
node.next=node
else:
cur = self.__head
while cur.next != self.__head:
cur = cur.next
# 退出循环,cur指向尾节点
node.next = self.__head
self.__head = node
# cur.next=node 与下一句代码等价
cur.next = self.__head
添加元素:尾插法
def append(self,item):
'''链表尾部添加元素,尾插法'''
node=Node(item)
if self.is_empty():
self.__head=node
node.next=node
else:
cur = self.__head
while cur.next != self.__head:
cur = cur.next
#node.next=cur.next 与下一句代码等价
node.next=self.__head
cur.next=node
添加元素:指定位置添加元素
def insert(self,pos,item):
'''指定位置添加元素
pos从0开始索引'''
if pos<=0:
self.add(item)
elif pos>(self.length()-1):
self.append(item)
else:
pre = self.__head
count = 0
while count < (pos-1):
count += 1
pre = pre.next
# 当循环退出后,pre指向pos-1位置
node = Node(item)
node.next = pre.next
pre.next = node
删除元素
def remove(self,item):
'''删除节点'''
if self.is_empty():
return
cur=self.__head
pre=None
while cur.next!=self.__head:
if cur.elem==item:
#先判断此节点是否是头节点
if cur==self.__head:
# 头节点的情况
#找尾节点
rear=self.__head
while rear.next!=self.__head:
rear=rear.next
self.__head=cur.next
rear.next=self.__head
else:
#中间节点
pre.next=cur.next
return
else:
pre=cur
cur=cur.next
#退出循环,cur指向尾节点
if cur.elem==item:
if cur==self.__head:
#链表只有一个节点
self.__head=None
else:
pre.next=cur.next
查找元素
def search(self,item):
'''查找节点是否存在'''
if self.is_empty():
return False
cur=self.__head
while cur.next!=self.__head:
if cur.elem == item:
return True
else:
cur = cur.next
#退出循环,cur指向尾节点
if cur.elem==item:
return True
return False