首页 > 编程知识 正文

python列表结构,python中序列的结构

时间:2023-05-03 09:49:10 阅读:232085 作者:3365

1.队列

队列是一种特殊的线性表,先进先出,只允许在前端进行删除,在后端进行插入操作,它的操作方式与堆栈类似,区别在于队列只允许在后端插入数据。

在python中有相应的类:

import Queueq = Queue.Queue()for i in range(4): q.put(i) #将一个值放入队列中while not q.empty(): print q.get(), #将值取出#先进先出的,你应该猜到了会输出什么。0 1 2 3

条件:

如果列表中只有一个元素,头节点和末节点均可指向它如果列表中没有元素, 头节点和末节点的指针均指向None

要一个空队列出队,返回None

2.入队

入队需要分为两种情况:

要入的队为空队列

要入的队为非空队列

因此设计相应的算法:

如果列表为空,头节点和末节点均指向新节点node否则,放到末节点之后 class Node(object): def __init__(self,data): self.data = data self.next = Noneclass Queue(object): def __init__(self): self.head = None self.tail = None def enqueue(self,data): node = Node(data) if self.head is None and self.tail is None: self.head = node self.tail = node else: self.tail.next = node self.tail = node

算法的时间,空间复杂度均为O(1)

3.出队

出队则要分成三种情况讨论:
要出的队列为空,只有一个节点,或者有不止一个节点,设计如下算法:

如果list为空,返回None

if list有一个节点
2.1 存储头节点的值
2.2 把头,尾节点指向None
2.3 返回头节点的值

else:
3.1 存储头节点的值
3.2 将头节点转到下一个节点
3.3 返回头节点的值

def dequeue(self): if self.head is None and self.tail is None: return None data = self.head.data if self.head == self.tail: self.head = None self.tail = None else: self.head = self.head.next return data

算法的时间,空间复杂度均为O(1)

4.后进先出队列 q = Queue.LifoQueue()for i in range(5): q.put(i)while not q.empty(): print q.get(), #输出:4 3 2 1 0
历史中提交的图片或压缩文件

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。