python-用代码实现队列,处理斐波那契数列
队列在进行数据操作时必须遵循“先进先出(Firstin Firstout,FIFO)”的原则,这一特点决定了队列的基本操作需要在其两端进行
队列(Queue)的基本操作通常在队列的两端被执行,其中执行插入元素操作的一端被称为队尾(rear);执行删除元素操作的一端被称为队头(front)。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | class Q: def __init__( self ): self .maxQSize = 10 self .s = [ None for x in range ( self .maxQSize)] self .front = 0 self .rear = 0 def IsEmptyQ( self ): if self .front = = self .rear: result = True else : result = False return result def EnQ( self ,x): if ( self .rear < self .maxQSize - 1 ): self .s[ self .rear] = x self .rear + = 1 print (f "进队列{self.rear}:{x}" ) else : return def DeQ( self ): if self .IsEmptyQ(): print ( "队列空" ) else : deq = self .s[ self .front] self .front + = 1 return deq def GetHead( self ): if self .IsEmptyQ(): print ( "队列空" ) else : return self .s[ self .front] """ 先将当前月份的初始值设置为1,起始的小兔总数(队头元素)和第一个月的小兔总数(队尾元素)依次放入队列中, 此时的队尾元素即为当前月份的小兔总数。 """ def Fibonacci(n): qu = Q() qu.EnQ( 1 ) qu.EnQ( 1 ) start = 0 while start < n - 2 : numHead = qu.DeQ() numRear = qu.GetHead() qu.EnQ(numHead + numRear) start + = 1 return qu.s[qu.rear - 1 ] print (Fibonacci( 5 )) |
作者: yetangjian
出处: https://www.cnblogs.com/yetangjian/p/16030122.html
关于作者: yetangjian
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 原文链接 如有问题, 可邮件(yetangjian@outlook.com)咨询.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~