Python数据结构知识之队列(三)
2018-01-22 本文已影响8人
withism
队列的简单实现
Queue.py
# Author: Allen Guo
# Data: 2018-01-22
# For github repos please check <https://github.com/wilixx/python_training> .
# For more about the author, see to <www.whoispm.com> but note the disclaimer there.
class Queue:
def __init__(self):
self.items = []
def isEmpty(self):
return self.items == []
def enqueue(self, item):
self.items.insert(0,item)
def dequeue(self):
return self.items.pop()
def size(self):
return len(self.items)
Hot Potato游戏(源程序有误,已经修改)
HotPotato.py
# Author: Allen Guo
# Data: 2018-01-22
# For github repos please check <https://github.com/wilixx/python_training> .
# For more about the author, see to <www.whoispm.com> but note the disclaimer there.
from Queue import Queue
def hotPotato(namelist, num):
simqueue = Queue()
for name in namelist:
simqueue.enqueue(name)
while simqueue.size() > 1:
for i in range(num-1):#Note that the Number must minus 1,here modified my me.
simqueue.enqueue(simqueue.dequeue())
simqueue.dequeue()
return simqueue.dequeue()