"""
题目:斐波那契数列。
程序分析:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……。
这里所有的斐波那契数列都是以0开头来算
"""
import functools def answer1():
"""
输出100000以内斐波那契数列
:return:
"""
print("\n输出一", end=":")
a = 0
print(a, end=",")
b = 1
print(b, end=",")
c = a + b
while c < 100000:
print(c, end=",")
a = b
b = c
c = a + b answer1() def answer2():
"""
参考答案用到了多变量赋值
:return:
"""
print("\n输出二", end=":")
a, b = 0, 1
print(a, end=",")
while b < 100000:
print(b, end=",")
a, b = b, a + b answer2() def answer3(n, m):
"""
利用递归来实现
:param n:
:return:
"""
if n == 0:
print("\n输出三", end=":")
print(n, end=",")
if m < 100000:
print(m, end=",")
n, m = m, n + m
answer3(n, m)
else:
return answer3(0, 1) def answer4():
"""
利用代数公式计算,公式可参考example006_FormulaDerivation文件:
F(n)=(√5/5)*{[(1+√5)/2]^n - [(1-√5)/2]^n}。
:return:
"""
print("\n输出四", end=":")
i = 0
n = 0
while n < 100000:
print(int(n), end=",")
i += 1
n = (5 ** 0.5 / 5) * (((1 + 5 ** 0.5) / 2) ** i - ((1 - 5 ** 0.5) / 2) ** i) answer4() def answer5(n):
"""
根据输入整数n,获取前n个斐波那契数
:param n:
:return:
"""
print("\n输出五", end=":")
a = 0
print(a, end=",")
b = 1
for i in range(1, n):
print(b, end=",")
a, b = b, a + b answer5(26) def answer6(n):
"""
利用另一种递归来计算,注意与answer3(n, m)区分
其中用到了内嵌函数
:param n:
:return:
"""
print("\n输出六", end=":") def getOne(index):
if index == 1:
return 0
if index == 2:
return 1
num = getOne(index - 2) + getOne(index - 1)
return num for i in range(1, n+1):
print(getOne(i), end=",") answer6(26) def answer7(n):
"""
利用数组来计算
:param n:
:return:
"""
print("\n输出七", end=":")
num = [0, 1]
for i in range(2, n):
num.append(num[-1] + num[-2])
print(num) answer7(26) def answer8(n):
"""
利用公司算前n个
:param n:
:return:
"""
print("输出八", end=":")
for i in range(0, n):
num = (5 ** 0.5 / 5) * (((1 + 5 ** 0.5) / 2) ** i - ((1 - 5 ** 0.5) / 2) ** i)
print(int(num), end=",") answer8(26) def answer9(n):
"""
多变量赋值,获取前n个斐波那契数列
:param n:
:return:
"""
print("\n输出九", end=":")
a, b = 0, 1
while n:
print(a, end=",")
a, b, n = b, a + b, n - 1 answer9(26) @functools.lru_cache(None)
def answer10(n):
"""
在 Python 的 3.2 版本中,引入了一个非常优雅的缓存机器,即 functool 模块中的 lru_cache 装饰器。如果要在 python2 中使用 lru_cahce 需要安装 functools32。lru_cache 原型如下: @functools.lru_cache(maxsize=None, typed=False) 使用functools模块的lur_cache装饰器,可以缓存最多 maxsize 个此函数的调用结果,从而提高程序执行的效率,特别适合于耗时的函数。参数maxsize为最多缓存的次数,如果为None,则无限制,设置为2n时,性能最佳;如果 typed=True(注意,在 functools32 中没有此参数),则不同参数类型的调用将分别缓存,例如 f(3) 和 f(3.0)。 被 lru_cache 装饰的函数会有 cache_clear 和 cache_info 两个方法,分别用于清除缓存和查看缓存信息。 这里用一个简单的示例演示 lru_cache 效果:
from functools import lru_cache
@lru_cache(None)
def add(x, y):
print("calculating: %s + %s" % (x, y))
return x + y print(add(1, 2))
print(add(1, 2))
print(add(2, 3))
输出结果: calculating: 1 + 2
3
3
calculating: 2 + 3
5
从结果可以看出,当第二次调用 add(1, 2) 时,并没有真正执行函数体,而是直接返回缓存的结果。 有一个用 C 实现的,更快的,同时兼容 Python2 和 Python3 的第三方模块 fastcache 能够实现同样的功能。
:param n:
:return:
"""
if n == 1:
print("\n输出十", end=":")
assert n >= 1
m = 0 if n == 1 else answer10(1)+1 if n == 2 else answer10(n - 2) + answer10(n - 1)
print(m, end=",")
return m answer10(26) def answer11(n):
"""
reduce练习
:return:
"""
print("\n输出十一", end=":")
num = [0, 1]
for i in range(2, n):
num.append(functools.reduce(lambda x, y: x + y, num[-1: -3: -1]))
print(num) answer11(26) def answer12(n):
"""
练习sum 和列表切片
:param n:
:return:
"""
print("输出十二", end=":")
num = [0, 1]
for i in range(2, n):
num.append(sum(num[i-2: i]))
print(num) answer12(26) class Fibs:
"""
练习类,创建一个迭代器
"""
def __init__(self, n):
self.a = 0
self.b = 1
self.n = n
self.i = 1
print("输出十三", end=":") def __iter__(self):
return self def __next__(self):
if self.i > self.n:
raise StopIteration
print(self.a, end=",")
self.a, self.b = self.b, self.a + self.b
self.i += 1 f = Fibs(26)
for i in f:
pass

  

python学习——练习题(6)的更多相关文章

  1. python学习——练习题(10)

    """ 题目:暂停一秒输出,并格式化当前时间. """ import sys import time def answer1(): &quo ...

  2. python学习——练习题(9)

    """ 题目:暂停一秒输出. 程序分析:使用 time 模块的 sleep() 函数. http://www.runoob.com/python/python-date- ...

  3. python学习——练习题(4)

    """ 题目:输入某年某月某日,判断这一天是这一年的第几天? """ import datetime import time from fu ...

  4. python学习——练习题(1)

    """ 题目:有四个数字:1.2.3.4,能组成多少个互不相同且无重复数字的三位数?各是多少? """ import itertools d ...

  5. python学习——练习题(13)

    """ 题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身.例如:153是一个" ...

  6. python学习——练习题(12)

    """ 题目:判断101-200之间有多少个素数,并输出所有素数. 质数(prime number)又称素数,有无限个. 质数定义为在大于1的自然数中,除了1和它本身以外 ...

  7. python学习——练习题(11)

    """ 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 1 1 2 ...

  8. python学习——练习题(8)

    """ 题目:输出 9*9 乘法口诀表. """ def answer1(): """ 自己用最普通的双重循环 ...

  9. python学习——练习题(7)

    """ 题目:将一个列表的数据复制到另一个列表中. """ import copy def validate(a, b): "&q ...

随机推荐

  1. I.MX6 linux eGalaxTouch 自动获取设备节点

    I.MX6 linux eGalaxTouch 自动获取设备节点 \\\\\\\\\\\\\\-*- 目录 -*-///////////// | 一. 需求: | 二. /proc/bus/input ...

  2. 在CentOS 7上安装GitLab

    网上安装gitlab的方法有一堆,由于墙的原因,没有一个能安装成功,最后终于在中文版官网上面找到了RPM包可以下载,进行一键安装: 中文官网地址:http://www.gitlab.cc/ 下载地址为 ...

  3. tcp流式套接字和udp数据报套接字编程区别

    1. 流式套接字采用字节流方式进行传输,而数据报套接字 使用数据报形式传输数据2. tcp套接字会产生粘包,udp有消息边界,不会形成粘包.3. tcp编程可以保证消息的完整性,udp则不能保证4. ...

  4. MySQL中表的复制

    1.语法 create table 表名 select .. from 表名 where 条件; 2.示例 1.复制MOSHOU.sanguo表的全部记录和字段,sanguo2 create tabl ...

  5. SQL Server Profiler 跟踪远程服务器的语句

    同事测试软件报错,想连Ta的数据库跟踪下语句,结果提示:      对比了下自己的探查器设置,勾选几个事件就可以了:

  6. 菜鸟夜谈android反编译

    工具: apktool:https://code.google.com/p/android-apktool/ dex2jar: https://code.google.com/p/dex2jar/ j ...

  7. HDU - 6172:Array Challenge (BM线性递推)

    题意:给出,三个函数,h,b,a,然后T次询问,每次给出n,求sqrt(an); 思路:不会推,但是感觉a应该是线性的,这个时候我们就可以用BM线性递推,自己求出前几项,然后放到模板里,就可以求了. ...

  8. BZOJ1066 SCOI2007 蜥蜴 【网络流-最大流】

    BZOJ1066 SCOI2007 蜥蜴 Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离 ...

  9. 使用 MSBuild 响应文件 (rsp) 来指定 dotnet build 命令行编译时的大量参数

    在为开源项目 easiwin/MSTestEnhancer 进行持续集成编译时,需要在编译命令中传入较多的参数.这对于新接手此项目的人来说,成本还是高了一点儿.本文将介绍 MSBuild 响应文件 ( ...

  10. Python猴子补丁

    属性在运行时的动态替换,叫做猴子补丁(Monkey Patch). 为什么叫猴子补丁 属性的运行时替换和猴子也没什么关系,关于猴子补丁的由来网上查到两种说法: 1,这个词原来为Guerrilla Pa ...