队列在进行数据操作时必须遵循“先进先出(Firstin Firstout,FIFO)”的原则,这一特点决定了队列的基本操作需要在其两端进行

队列(Queue)的基本操作通常在队列的两端被执行,其中执行插入元素操作的一端被称为队尾(rear);执行删除元素操作的一端被称为队头(front)。

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))

最新文章

  1. php实现数据粘性例子
  2. MongoDB-Getting Started with the C# Driver
  3. win7-32 系统 + VS2010 配置 glew
  4. R中的统计检验函数
  5. 今天装了一个RTI工具
  6. HDU-1042 N!
  7. leetcode reverse bits python
  8. mysql 在大型应用中的架构演变
  9. XMPP协议、IM、客户端互联详解
  10. Map集合的四种遍历
  11. PL/SQL 游标的使用
  12. TTL与非门电路分析
  13. go的生产者-消费者模式
  14. Dynamics 365新引入了多选选项集类型字段
  15. Springboot中对Service层进行集成测试时注意点
  16. 潭州课堂25班:Ph201805201 django 项目 第三十四课 后台文章标签更新功能 ,创建功能实现(课堂笔记)
  17. Houdini技术体系 基础管线(三) :UE4 Landscape Component的多选支持 下篇
  18. c、c++函数随机
  19. numpy 中的 broadcasting 理解
  20. Oracle 11G Client客户端安装

热门文章

  1. 为什么后台给前台Date是时间戳,而前台给后台则直接是时间字符串?
  2. C++中的常见错误
  3. AFNetWorking 文件上传 By-H罗
  4. 「 题解 」P2487 [SDOI2011]拦截导弹
  5. 【Gym100837F】Controlled Tournament(状压Dp 搜索剪枝)
  6. Solution -「ARC 110F」Esoswap
  7. Solution -「CF 1370F2」The Hidden Pair (Hard Version)
  8. 利用 kubeasz 给 suse 12 部署 kubernetes 1.20.1 集群
  9. Redis 忽然变慢了如何排查并解决?
  10. Django创建的第一个项目(2)