1. 编写程序实现链队列的各种基本运算:初始化、销毁、清空、判断是否为空队列、求队列的长度、取队列的头元素、入队、出队。在此基础上设计一个主程序完成如下功能:(1)初始化链队列q;(2)判断链队列q是否为空;(3)依次入队元素a,b,c;(4)出队一个元素,并输出该元素;(5)输出链队列q的长度;(6)依次入队元素d,e,f;(7)输出链队列q的长度;(8)出队所有元素,并输出出队序列;(9)销毁链队列q
时间: 2023-06-19 10:09:24 浏览: 96
以下是链队列的基本运算实现,包括初始化、销毁、清空、判断是否为空队列、求队列的长度、取队列的头元素、入队、出队:
```python
class QueueNode:
def __init__(self, data=None):
self.data = data
self.next = None
class LinkedQueue:
def __init__(self):
self.front = QueueNode()
self.rear = self.front
def is_empty(self):
return self.front == self.rear
def get_length(self):
length = 0
p = self.front.next
while p:
length += 1
p = p.next
return length
def get_head(self):
if self.front == self.rear:
return None
return self.front.next.data
def enqueue(self, data):
node = QueueNode(data)
self.rear.next = node
self.rear = node
def dequeue(self):
if self.front == self.rear:
return None
p = self.front.next
self.front.next = p.next
if self.rear == p:
self.rear = self.front
return p.data
def clear(self):
self.front.next = None
self.rear = self.front
def destroy(self):
self.front = None
self.rear = None
```
接下来是主程序,按照题目要求完成各个功能:
```python
if __name__ == '__main__':
# 初始化链队列
q = LinkedQueue()
print("初始化链队列完成")
# 判断链队列是否为空
if q.is_empty():
print("链队列为空")
else:
print("链队列不为空")
# 依次入队元素a,b,c
q.enqueue('a')
q.enqueue('b')
q.enqueue('c')
print("元素a,b,c已入队")
# 出队一个元素,并输出该元素
print("出队一个元素:", q.dequeue())
# 输出链队列的长度
print("链队列长度为:", q.get_length())
# 依次入队元素d,e,f
q.enqueue('d')
q.enqueue('e')
q.enqueue('f')
print("元素d,e,f已入队")
# 输出链队列的长度
print("链队列长度为:", q.get_length())
# 出队所有元素,并输出出队序列
print("出队序列为:")
while not q.is_empty():
print(q.dequeue())
# 销毁链队列
q.destroy()
print("销毁链队列完成")
```
运行结果如下:
```
初始化链队列完成
链队列为空
元素a,b,c已入队
出队一个元素: a
链队列长度为: 2
元素d,e,f已入队
链队列长度为: 5
出队序列为:
b
c
d
e
f
销毁链队列完成
```
阅读全文