一、协程函数:

    协程函数的语法:

    def eater(name):

  1. print('%s说:我开动啦' %name)
    food_list=[]
    while True:
    food=yield food_list
    food_list.append(food)
    print('%s 吃了 %s' %(name,food))
  2. e=eater('egon')
    e.send(None) #next(e) #初始化装饰器,
    e.close() #关闭
        解决方法:第一步:初始化函数Next(),第二部:给yield传值
    二、面向过程:
        面向过程:核心是过程二字,过程就是解决问题的步骤,
    基于面向过程去设计程序就像是在设计,一条工业流水线,是一种机械式的思维方式    #优点:程序结构清晰,可以把复杂的问题简单化,流程化
  1.     #缺点:可扩展性差,一条流线只是用来解决一个问题
        #应用场景:linux内核,git,httpd,shell脚本
    三、递归:
      
      递归调用:在调用一个函数的过程中,直接或间接地调用了函数本身

    递归效率低,需要在进入下一次递归时保留当前的状态
   解决方法是尾递归,即在函数的最后一步(而非最后一行)调用自己
   但是python又没有尾递归,且对递归层级做了限制

  1. 必须有一个明确的结束条件

  2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少

  3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,              栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)

  1.   递归的执行分为两个阶段:
  1.   1 递推
      2 回溯
      
    def age(n):
  2.  
  3.    if n == 1:
  1.    return 18
       return age(n-1)+2
         print(age(5))

  2. 四、二分法:
        
    l=[1,2,10,2,30,40,33,22,99,31]
  1. def search(num,l):
    print(l)
    if len(l) > 1:
    mid=len(l)//2
    if num > l[mid]:
    #in the right
    l=l[mid:]
    search(num,l)
    elif num < l[mid]:
    #in the left
    l=l[:mid]
    search(num,l)
    else:
    print('find it')
    else:
    if num == l[0]:
    print('find it')
    else:
    print('not exists')
  2. search(100,l)
  1.  
  1.  
  1.  
  1.  

  1.   

python之协程函数、递归、二分法的更多相关文章

  1. python 3 协程函数

    python 3 协程函数 1:把函数的执行结果封装好__iter__和__next__,即得到一个迭代器 2:与return功能类似,都可以返回值,但不同的是,return只能返回一次值,而yiel ...

  2. Python之协程函数

    Python之协程函数 什么是协程函数:如果一个函数内部yield的使用方法是表达式形式的话,如x=yield,那么该函数成为协程函数. def eater(name): print('%s star ...

  3. Python基础(协程函数、内置函数、递归、模块和包)-day05

    写在前面 上课第五天,打卡: 凭着爱,再回首: 一.协程函数(生成器:yield的表达式形式) 1.yield 的语句形式: yield 1 - 这种方式在 Python基础(函数部分)-day04  ...

  4. python基础-协程函数、递归、模块、包等内容

    1. 协程函数 1.1 yield基本用法 yield作用 1.把函数的执行结果封装好,即封装__iter__和__next__,即得到一个迭代器 2.与return功能类似,都可以返回值,但不同的是 ...

  5. python自动化 协程函数、二分查找、模块搜索

    协程函数 yiled: 把函数的执行结果封装好__iter__和__next__得到一个迭代器 与return功能类似,都可以返回值,但是return只能返回一次只 def fun(count): p ...

  6. python协程函数、递归、匿名函数与内置函数使用、模块与包

    目录: 协程函数(yield生成器用法二) 面向过程编程 递归 匿名函数与内置函数的使用 模块 包 常用标准模块之re(正则表达式) 一.协程函数(yield生成器用法二) 1.生成器的语句形式 a. ...

  7. python基础之协程函数、列表表达式、生成器表达式

    一.协程函数 协程函数的定义?如果在一个函数内部yield的使用方式是表达式形式的话,如x=yield,那么该函数称为协程函数 协程函数补充: def init(func): def wrapper( ...

  8. python协程函数应用 列表生成式 生成器表达式

    协程函数应用 列表生成式 生成器表达式   一.知识点整理: 1.可迭代的:对象下有_iter_方法的都是可迭代的对象 迭代器:对象._iter_()得到的结果就是迭代器 迭代器的特性: 迭代器._n ...

  9. Py修行路 python基础 (十二) 协程函数应用 列表生成式 生成器表达式

    一.知识点整理: 1.可迭代的:对象下有_iter_方法的都是可迭代的对象 迭代器:对象._iter_()得到的结果就是迭代器 迭代器的特性: 迭代器._next_() 取下一个值 优点: 1.提供了 ...

随机推荐

  1. 《全栈性能Jmeter》-1性能方向职业发展

  2. Linux挂载共享命令

    用于多台Linux服务器之间共享数据: mount -t cifs -o username=administrator,password=" //10.10.51.202/m /bak

  3. xcode 各版本下载地址及其它工具下载地址

    官方下载地址:https://developer.apple.com/downloads/

  4. unity3d对象池的使用

    说对象池之前首先来看看单例类和单例脚本的区别.这里有介绍 http://blog.csdn.net/lzhq1982/article/details/12649281 使用对象池的好处是不用每次都创建 ...

  5. nodejs连接数据库的增删改查

    连接数据库后需要用代码操作的是,传入mysql语句,和参数,然后就是回调了 新增 // 新增 app.post('/process_post', urlencodedParser, function ...

  6. 大数据项目(MTDAP)随想

    Spark MLlib进行example测试的时候,总是编译不通过,报少包<Spark MLlib NoClassDefFoundError: org/apache/spark/ml/param ...

  7. C# And Java 3DES加解密 ECB模式/PKCS7

    c#: /// <summary>     /// 完整     /// </summary>     public class TripleDESHelper1     { ...

  8. 关于oracle中的数字类型

    1.关于number类型. 以下是从其文档中摘录出的一句话: p is the precision, or the total number of significant decimal digits ...

  9. Apache Storm Installation

    安装的过程参照此处的过程介绍(https://www.tutorialspoint.com/apache_storm/apache_storm_installation.htm) 安装的过程要安装3个 ...

  10. Verdi如何编译design并打开

    HDL Source文件的编译 针对Verilog文件的编译: 使用vericom工具,将verilog source文件写入一个run.f中,如: system.v pram.v TopModule ...