Python | 排队取奶茶

  • 队列的基本概念(队头、队尾)和特点(先入先出)

在 Python 语言中,标准库中的queue模块提供了多种队列的实现,比如普通队列和优先级队列,因此你可以使用queue.Queue类来创建队列,不过我们依旧可以使用列表来模拟队列的实现。

  • 获取队列的长度,即队列中元素的数量,通常使用列表的len()函数来获取
  • 判断队列是否为空,可以通过if not queue来判定
  • 入队操作,将新的元素添加到队列的尾部,使用列表的append()函数来实现
  • 出队操作,获取并移除队列的头部元素,可以通过pop(0)函数传递索引来实现。
  • 访问队列的头部元素,但不会将其移除,使用索引访问第一个元素queue[0]
python 复制代码
#导入queue模块
import queue

#创建一个对列
q = queue.Queue()

#通过put实现入队操作
q.put(1)
q.put(2)
q.put(3)

# 通过get()实现出队操作
item = q.get() #出队并返回队列中的元素
print(item)  #输出1

也可以用列表模拟队列(上道题用列表实现了栈):

python 复制代码
ueue = []

#入队操作
queue.append("Tom")
queue.append("Jerry")
queue.append("Mike")

#出队操作
remove_person = queue.pop(0)  #弹出并返回队列中的第一个元素

#判断队列是否为空:
if not queueL
    print("队列为空")
else:
    print(f"队头元素:{queue[0]}")

由此可见,在列表中,如果直接pop(),那么将会弹出列表的最末尾一个值;而如果pop(0),那么将会弹出列表中的第一个元素

按照列表模拟队列的写法如下:

python 复制代码
n = int(input())
persons = input().split()
m = int(input())

for _ in range(m):
    ope = input().split()
    opt = int(ope[0])
    if opt == 1:
        if persons:
            move_person = persons.pop(0)
    if opt == 2:
        persons.append(ope[1])
if persons:
    print(persons.pop(0))
else:
    print("There are no more people in the queue.")

按照queue模块的写法如下:

相关推荐
小白学大数据3 分钟前
知网数据实战:爬虫 + 网络分析打造论文关键词图谱
爬虫·python·scrapy
摇滚侠5 分钟前
SpringMVC 入门到实战 域对象共享数据 33-43
java·后端·spring·intellij-idea
码语智行7 分钟前
GDB 文件导入流程分析
java
jjjava2.07 分钟前
软件测试与开发全流程解析
java·功能测试·测试用例
SilentSamsara7 分钟前
Prompt 工程实战:System Prompt 设计、Few-shot 与 Chain-of-Thought
人工智能·python·青少年编程·prompt
Shadow(⊙o⊙)10 分钟前
QT常用控件3.0,font字体设置,toolTip提示,focusPolicy焦点定位原则,中型控件StyleSheet样式表。
服务器·开发语言·前端·c++·qt
零陵上将军_xdr10 分钟前
大模型开发02 - 提示词工程
人工智能·python
CodeStats10 分钟前
JavaWeb 造轮者视角:Spring Boot 启动核心思想与完整链路解析
java·spring boot·后端
veminhe11 分钟前
解决了调用deepseek接口报的错
python
Shadow(⊙o⊙)13 分钟前
QT常用控件2.0,windowOpacity窗口透明度,Cursor光标设置
开发语言·c++·qt