Δ汉诺塔例子

# 定义三个全局的列表
la = []
lb = []
lc = [] stepn = 0 def create_hano(n):
'''构建由n个圆盘组成的汉诺塔'''
global la
la = [i for i in range(n, 0, -1)] def move(src, dest):
'''从src柱子上最上面的圆盘移动到dest柱子上'''
dest.append(src.pop())
global stepn
stepn += 1 input() print('柱子A:',la)
print('柱子B:',lb)
print('柱子C:',lc) def start_game(src, tmp, dest, n):
if n == 1:
move(src, dest)
return None
if n < 1:
return -1
start_game(src, dest, tmp, n-1)
start_game(src, tmp, dest, 1)
start_game(tmp, src, dest, n-1) create_hano(4)
print('柱子A:',la)
print('柱子B:',lb)
print('柱子C:',lc)
start_game(la, lb, lc, 4)
print(stepn)
  • 生成器(generator):
  • 迭代器(Iterator):

      next()得到成员的:generator

  • 可迭代(Iterable):

    能用for遍历的:str, list, tuple, dict, set, generator, range
    collections模块中定义的Iterator和Iterable类型

# 从1开始的fib
def fib(n):
a, b = 0, 1
while n > 0:
# print(b)
yield b # 随着生成器调用next方法,得到yield的值
a, b = b, a+b
n -= 1
return 'done' g = fib(10)
print(g)
  • 匿名函数 lambda : 适合函数功能简洁的
f = lambda x : True if x % 2 == 0 else False
print(type(f)) print(f(101)) f = lambda : print('hello world')
f() f = lambda x, y : x * y
print(f(10, 14)) f = lambda x, y=2 : x ** y
print(f(5, 5)) f = lambda x, *arg : print(x, arg)
print(f(1, 2,3,4,5,6))
  • 高阶函数:函数为参
  • map():对多个参数进行同一操作
    def test(n):
    return n ** 3 # g = map(test, (1,2,3,4))
    g = map(lambda x : x**3, (1,2,3,4))
    print(type(g)) print(next(g))
    print(next(g))
    print(next(g)) '''
    for res in g:
    print(res)
    '''
    l = list(g)
    print(l)
    '''
    练习1:
    生成一个由5个10以内随机整型数组成的列表,使用高阶函数map实现将5个整型数分别转换为字符串
    '''
    import random l = [random.randrange(10) for i in range(5)]
    print(l)
    l = list(map(str, l))
    print(l) '''
    练习2:
    将列表中每一个元素都转换为一个标准的标题,首字符大写其它小写
    l = ['hello world', 'Good AFTERNOON', 'morning']
    '''
    l = ['hello world', 'Good AFTERNOON', 'morning']
    l = list(map(lambda x : x.title(), l))
    print(l)
  • filter():过滤
    res = filter(lambda x : x % 2 == 0, [random.randrange(100) for i in range(10)])
    print(list(res))
  • sorted():排序,有key值默认为NONE
    l = ['hello', 'Yes', 'PYTHON', 'world', 'Go']
    res = sorted(l, key=str.lower, reverse=True) # 按小写排序
    print(res)
  • reduce() :两个变量后跟类型  functools
from functools import reduce

def f(x, y):
return x * 10 + y n = reduce(f, (1,5,6,7))
print(type(n), n) n = reduce(lambda x,y : x*y, (1,2,3,4,5,6))
print(n)
'''
实现一个将字符串转换为整型数的函数str2int()
'1432' ----> 1432 不允许调用int函数
'''
def str2int(s):
g = map(lambda x:ord(x)-ord('0'), s)
return reduce(lambda x, y:x*10+y, g) print(str2int('1423'))
  • 装饰器(decorator):修饰函数

 

import datetime
d = datetime.date()
print(d)
'''
# 函数作为返回值
def test():
return str f = test()
print(f(1234)) import functools def decorator(f):
@functools.wraps(f) # 此装饰器作用是将f的函数名赋值给wrapper
def wrapper(*args, **kw):
'''装饰器的内部函数'''
# print(args, kw)
print('hello python')
# print(f.__name__)
return f(*args, **kw)
return wrapper @decorator
def show(name1, name2):
'''验证装饰器功能的小函数'''
print('hello %s and %s' % (name1, name2))
return 100 print(show.__name__)
print(show.__doc__)
res = show('aa', 'bb') # show = decorator(show)
print(res)

  带参数的装饰器

import functools

def log(text, text2):
def decorator(f):
@functools.wraps(f)
def wrapper(*args, **kw):
print('log', text, text2)
print('这个装饰器好吧?')
return f(*args, **kw)
return wrapper
return decorator @log('argument', 'haha')
def now():
print('2018-12-12') now() # now = log('argument')(now)

Python_day6的更多相关文章

  1. python_day6学习笔记

    一.Logger模块 logging.basicConfig函数 可通过具体参数来更改logging模块默认行为,可用参数有 filename: 用指定的文件名创建FiledHandler(后边会具体 ...

随机推荐

  1. c#继承 里氏转化原则

    继承: 是c#中面向对象一个重要概念: 用一个已经存在的类去定义一个新的类 新的类叫做   子类/派生类 已经存在的类叫做   父类/基类 c#中所以类的最终基类都是Object类 声明 访问修饰符  ...

  2. springBoot 整合mybaits 逆向工程

    pom.xml文件中增加配置项 <build> <plugins> <plugin> <groupId>org.springframework.boot ...

  3. MySQL Antelope和Barracuda的区别分析

    Antelope是innodb-base的文件格式,Barracude是innodb-plugin后引入的文件格式,同时Barracude也支持Antelope文件格式.两者区别在于: 文件格式 支持 ...

  4. centos7 安装percona-toolkit工具包的安装和使用

    一.检查和安装与Perl相关的模块 PT工具是使用Perl语言编写和执行的,所以需要系统中有Perl环境. 依赖包检查命令为: rpm -qa perl-DBI perl-DBD-MySQL perl ...

  5. async+await一起使用

    /** get 请求 * @param {接口地址} url * @param {请求参数} params */ get(url,params){ return new Promise((resolv ...

  6. 在consul上注册web服务

    1. 创建web服务 IDEA->File->New->Project->Empty Project,project name取名provider,点击finish 2. 创建 ...

  7. 【亲测】502 Bad Gateway 怎么解决?

    502 Bad Gateway 怎么解决? 1.什么是502 badgateway 报错 简单来说 502 是报错类型代码,bad gateway 错误的网关. 2.产生错误的原因 连接超时 具体原因 ...

  8. gentoo 图像方面的软件

    图像方面的软件一般包括:查看图像,屏幕截图,图像修改. 查看图像简单的可以安装 feh,但是 feh 一般作为墙纸来用.稍微好一些的是 gqview. 屏幕截图可以用 screengrab,使用的时候 ...

  9. 下载安装 STS(Spring Tool Suite),推荐对应 Eclipse 版本号,适用于Windows32位(xp、2003)

    sts下载地址:https://spring.io/tools/sts/legacy 虽然sts内置了版本对应的eclipse,仍推荐使用当前环境下稳定使用的eclipse版本. Start 找到ec ...

  10. js代码技巧

    1.js 中不常用的处理方法 //取整 parseInt(a,10); //Before Math.floor(a); //Before a>>0; //Before ~~a; //Aft ...