Δ汉诺塔例子

# 定义三个全局的列表
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. Mongodb 批量Upsert

    List<UpdateOneModel<Entity>> requests = new List<UpdateOneModel<Entity>>(ent ...

  2. vue 一些可以优化的地方

    第一招:化繁为简的Watchers 场景还原: created(){ this.fetchPostList() }, watch: { searchInputValue(){ this.fetchPo ...

  3. J2EE十三个技术规范

    从事Java开发的童鞋都知道,java是一种非常棒的语言,能够实现跨平台运行.它屏蔽了具体的平台环境的要求,也就是说,无论是windows,还是Unix.Linux系统,只要支持Java虚拟机,就可以 ...

  4. qrcode生成二维码

    代码: <!DOCTYPE html> <html lang="en" style="height: 99%"> <head> ...

  5. ARCore中根据屏幕坐标计算射线的算法

    ARCore中提供了根据屏幕坐标.视口大小及view. project矩阵计算从屏幕坐标发射一条射线的方法,此方法用于3D拾取. class Ray { public final Vector3f o ...

  6. 编程最好用的字体consolas

    python 自带idle最好用的字体consolas https://www.icourse163.org/learn/BIT-268001?tid=1002788003#/learn/forumd ...

  7. Django之Auth模块 实现登录,退出,自带session 与认证功能的一个重要的模块

    Auth模板 1. 什么是Auth模块,有什么用? django的auth的模块的使用: auth 是集合注册,登录,注销,session 多个功能集合在一起的模块 2. 使用Auth组件的默认aut ...

  8. GIT TEAMWORK

    Learn GIT TEAMWORK generalizations Congratulations, you now know enough to start collaborating on Gi ...

  9. jquery之find,filter,has对比

    find()方法找的是符合条件的后代,返回的是子元素. $('div').find('.intro').css('color','red'); //寻找div后代类为intro的元素 filter() ...

  10. HTML前期学习总结

    一.基本结构<!DOCTYPE html> //设置字符编码集格式<html> //<head> //网页头部 <title></title> ...