class LinkNode: #链队结点类 def __init__(self,data=None): #构造方法 self.data=data #data域 self.next=None #next域 class LinkQueue: #链队类 def __init__(self): #构造方法 self.front=None #队头指针 self.rear=None #队尾指针 def empty(self): #判断队是否为空 return self.front==None def push(self,e): #元素e进队 new_node = Node(e) # 创建新节点 if self.empty(): # 如果队列为空,则新节点既是队头也是队尾 self.front = new_node self.rear = new_node else: self.rear.next = new_node # 将新节点链到队尾 self.rear = new_node # 更新队尾指针 def pop(self): #出队操作 if self.empty(): # 如果队列为空,返回None return None node = self.front # 取出队头指针指向的节点 self.front = node.next # 更新队头指针 if self.front == None: # 如果删除的是最后一个节点,更新队尾指针 self.rear = None return node.data # 返回出队节点的数据 def gethead(self): #取队顶元素操作 if self.empty(): # 如果队列为空,返回None return None return self.front.data # 返回队头指针指向的节点的数据
时间: 2024-01-14 22:03:01 浏览: 67
这段代码实现了一个链队列的基本操作,包括判断队列是否为空、元素进队、出队操作、取队顶元素操作等。链队列是一种基于链表实现的队列,相比于顺序队列,在动态性方面更加灵活。这段代码中,LinkNode类表示链队列的节点,包含数据域和指向下一个节点的指针;LinkQueue类表示链队列本身,包含队头指针和队尾指针。在push方法中,如果队列为空,则新节点既是队头也是队尾,否则将新节点链到队尾,并更新队尾指针;在pop方法中,如果队列为空,则返回None,否则取出队头指针指向的节点并更新队头指针,如果删除的是最后一个节点,则更新队尾指针。gethead方法用于取队顶元素,如果队列为空,则返回None,否则返回队头指针指向的节点的数据。
相关问题
修改以下代码:MaxSize=5 #全局变量,假设容量为5 class LinkNode: #链队结点类 def __init__(self,data=None): #构造方法 self.data=[None] *MaxSize #data属性 self.next=None #next属性 class LinkQueue: #链队类 def __init__(self): #构造方法 self.front=None #队头指针 self.rear=None #队尾指针 def empty(self): # 判断队是否为空 return self.front == self.rear def push(self, e): # 元素e进队 s = LinkNode(e) # 新建结点s if self.empty(): # 原链队为空 self.front = self.rear = s else: # 原链队不空 self.rear.next = s # 将s结点链接到rear结点后面 self.rear = s def pop(self): # 出队操作 assert not self.empty() # 检测空链队 if self.front == self.rear: # 原链队只有一个结点 e = self.front.data # 取首结点值 self.front = self.rear = None # 置为空队 else: # 原链队有多个结点 e = self.front.data # 取首结点值 self.front = self.front.next # front指向下一个结点 return e def gethead(self): # 取队头元素 assert not self.empty() # 检测空链队 e = self.front.data # 取首结点值 return e def size(self): # 返回队中元素个数 return ((self.rear - self.front + MaxSize) % MaxSize) #主程序 if __name__ == '__main__': t=LinkQueue() t.push(4) t.push(6) t.push(1) t.push(9) print(" 队列元素个数:%d" % (t.size())) print() print("队头元素: %d" % (t.gethead())) print(" 出队元素:%d" % (t.pop())) print(" 队列元素个数:%d" % (t.size())) print()
MaxSize=5 #全局变量,假设容量为5
class LinkNode: #链队结点类
def __init__(self,data=None): #构造方法
self.data=data #data属性
self.next=None #next属性
class LinkQueue: #链队类
def __init__(self): #构造方法
self.front=None #队头指针
self.rear=None #队尾指针
def empty(self): # 判断队是否为空
return self.front == None and self.rear == None
def push(self, e): # 元素e进队
s = LinkNode(e) # 新建结点s
if self.empty(): # 原链队为空
self.front = self.rear = s
else: # 原链队不空
self.rear.next = s # 将s结点链接到rear结点后面
self.rear = s
def pop(self): # 出队操作
assert not self.empty() # 检测空链队
if self.front == self.rear: # 原链队只有一个结点
e = self.front.data # 取首结点值
self.front = self.rear = None # 置为空队
else: # 原链队有多个结点
e = self.front.data # 取首结点值
self.front = self.front.next # front指向下一个结点
return e
def gethead(self): # 取队头元素
assert not self.empty() # 检测空链队
e = self.front.data # 取首结点值
return e
def size(self): # 返回队中元素个数
p = self.front
n = 0
while p != None:
n += 1
p = p.next
return n
#主程序
if __name__ == '__main__':
t=LinkQueue()
t.push(4)
t.push(6)
t.push(1)
t.push(9)
print(" 队列元素个数:%d" % (t.size()))
print()
print("队头元素: %d" % (t.gethead()))
print(" 出队元素:%d" % (t.pop()))
print(" 队列元素个数:%d" % (t.size()))
print()
修改内容:
1. LinkNode类的构造方法中,将data的默认值改为None,因为如果不传入参数,data的值应该是空的。
2. LinkQueue类的empty方法中,判断条件应该是队头和队尾都为None才算是空队列。
3. LinkQueue类的size方法中,用指针p遍历队列,统计元素个数。
4. 主程序中,按照修改后的方法调用LinkQueue类的方法。
class LinkNode: #单链表结点类 def __init__(self,data=None): #构造函数 self.data=data #data属性 self.next=None #next属性 class LinkList: #单链表类 def __init__(self): #构造函数 self.head=LinkNode() #头结点head self.head.next=None def CreateListF(self, a): #头插法:由数组a整体建立单链表 def CreateListR(self, a): #尾插法:由数组a整体建立单链表 def geti(self, i): #返回序号为i的结点 p=self.head j=-1 while (j<i and p is not None): j+=1 p=p.next return p def Add(self, e): #在线性表的末尾添加一个元素e def getsize(self): #返回长度 p=self.head cnt=0 while p.next is not None: #找到尾结点为止 cnt+=1 p=p.next return cnt
好的,那么接下来我会帮助您补齐这段代码的缺失部分。请注意,以下代码仅供参考,具体实现可能因情况而异,您可以根据自己的需求进行修改:
```python
class LinkNode: #单链表结点类
def __init__(self,data=None): #构造函数
self.data=data #data属性
self.next=None #next属性
class LinkList: #单链表类
def __init__(self): #构造函数
self.head=LinkNode() #头结点head
self.head.next=None
def CreateListF(self, a): #头插法:由数组a整体建立单链表
for i in range(len(a)):
node = LinkNode(a[i])
node.next = self.head.next
self.head.next = node
def CreateListR(self, a): #尾插法:由数组a整体建立单链表
p = self.head
for i in range(len(a)):
node = LinkNode(a[i])
p.next = node
p = node
def geti(self, i): #返回序号为i的结点
p = self.head
j = -1
while (j < i and p is not None):
j += 1
p = p.next
return p
def Add(self, e): #在线性表的末尾添加一个元素e
p = self.head
while p.next is not None:
p = p.next
node = LinkNode(e)
p.next = node
def getsize(self): #返回长度
p = self.head
cnt = 0
while p.next is not None: #找到尾结点为止
cnt += 1
p = p.next
return cnt
```
阅读全文