有些超市设置有多个自助收银台,为便于管理,在自助收银区入口处顾客排成一队,每当一个自助收银台可以使用时,一个顾客就可以去结账。假设有两个自助收银台,按如上场景编写模拟程序。提示:考虑如何设置队
时间: 2024-11-15 07:33:14 浏览: 21
这是一个简单的模拟排队系统的问题,我们可以使用Python的`threading`库或者`queue`模块来解决。这里我会提供一个基于线程和队列的简单示例:
```python
import threading
from queue import Queue
class CheckoutCounter:
def __init__(self):
self.checkouts = 0
self.lock = threading.Lock()
self.queue = Queue()
def start_checkout(self):
with self.lock:
if not self.checkouts >= 2: # 如果还有空闲的收银台
self.checkouts += 1
print(f"开始新一次结账,当前收银台数量:{self.checkouts}")
thread = threading.Thread(target=self.wait_for_checkout)
thread.start()
def wait_for_checkout(self):
while True:
customer = self.queue.get() # 取得下一个顾客
# 这里可以模拟实际的结账过程,这里仅打印示例
print(f"{customer}正在结账...")
self.queue.task_done() # 结束后从任务列表移除
self.checkouts -= 1 # 结算完一个收银台,还原数量
class Customer:
def __init__(self, name):
self.name = name
# 主程序
def main():
counter = CheckoutCounter()
customers = ['Alice', 'Bob', 'Charlie', 'David', 'Eve'] # 假设5位顾客
for i in range(len(customers)):
customer = Customer(customers[i])
counter.queue.put(customer) # 将顾客放入队列
# 启动收银台
for _ in range(2):
counter.start_checkout()
# 等待所有顾客完成结账
counter.queue.join()
if __name__ == "__main__":
main()
阅读全文