Python 数据结构之队列的实现
Python队列
Queue队列是一种先进先出(FIFO)的数据类型,新的元素通过入队的方式添加进Queue的末尾,出队就是从Queue的头部删除元素.
用列表来做Queue:
queue=[]#初始化一个列表数据类型对象,作为一个队列 defenQ():#定义一个入栈方法 queue.append(raw_input('EnterNewString:').strip()) #提示输入一个入队的String对象,调用Str.strip()保证输入的String值不包含多余的空格 defdeQ():#定义一个出队方法 iflen(queue)==0: print"Cannotpopfromanemptyqueue!" else: print'Remove[',`queue.pop(0)`,']' #使用反单引号(``)来代替repr(),把String的值用引号扩起来,而不仅显示String的值 #queue.pop(0)总是将在队列中最前面的元素弹出 defviewQ():#定义一个显示队列中的内容的方法 printqueue CMDs={'u':enQ,'o':deQ,'v':viewQ} #定义一个Dict类型对象,将字符映射到相应的function.可以通过输入字符来执行相应的操作 defshowmenu():#定义一个操作菜单提示方法 pr=""" (E)nqueue (D)equeue (V)iew (Q)uit Enterchoice:""" whileTrue: whileTrue: try: choice=raw_input(pr).strip()[0].lower() #Str.strip()去除String对象前后的多余空格 #Str.lower()将多有输入转化为小写,便于后期的统一判断 #输入^D(EOF,产生一个EOFError异常) #输入^C(中断退出,产生一个keyboardInterrupt异常) except(EOFError,KeyboardInterrupt,IndexError): choice='q' print'\nYoupicked:[%s]'%choice ifchoicenotin'uovq': print'Invalidoption,tryagain' else: break ifchoice=='q': break CMDs[choice]() #获取Dict中字符对应的functionName,实现函数调用 if__name__=='__main__': showmenu()
队列和堆栈的实现方式很相似,区别在于队列总是先弹出第一个元素而堆栈总是先弹出最后一个元素.
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!