一.多层语法糖本质

""" 语法糖会将紧挨着的被装饰对象名字当参数自动传入装饰器函数中"""

def outter(func_name):
print('加载outter')
def wrapper(*args, **kwargs):
print('执行了wrapper')
res = func_name(*args, **kwargs)
return res
return wrapper def outter1(fun_name1):
print('加载了outter1')
def wrapper1(*args, **kwargs):
print('执行了wrapper1')
res1 = fun_name1(*args, **kwargs)
return res1
return wrapper1 def outter2(fun_name2):
print('执行了outter2')
def wrapper2(*args, **kwargs):
print('执行了wrapper2')
res2 = fun_name2(*args, **kwargs)
return res2
return wrapper2
@outter
@outter1
@outter2
def index():
print('from index')
index()
结果:
执行了outter2
加载了outter1
加载outter
执行了wrapper
执行了wrapper1
执行了wrapper2
from index

二.有参装饰器

一个模板
def outer(source_data):
def login_autn(func_name):
def inner(*args, **kwargs):
username = input('username>>:').strip()
password = input('password>>:').strip()
if source_data == '1':
print('使用字典方式处理')
elif source_data == '2':
print('使用其他方式处理')
elif source_data == '3':
print('使用某些方式处理')
else:
print('使用更多方式处理都行')
res = func_name(*args, **kwargs)
return res
return inner
return login_autn
@outer('3') #函数名+括号执行优先级别最高
def user():
print('我随便写的')
user()
结果:
username>>:thn #加密无判断
password>>:123 #加密无判断
使用某些方式处理
我随便写的

三.递归函数

递归函数的本质:自己直接或者简介的调用了自己本身
"""直接调用本身"""

def index():
print('我自己')
index()
index()
结果是997~1000个‘我自己’加报错
997~1000就是python中最大递归深度
"""可以调"""

"""间接调用本身"""

def index():
print('你好')
func()
def func():
print('我不好')
index()
func()
结果同理:我调用的是func所以‘我不好’开头交叉出现1000个左右的 ‘我不好’and‘你好’等

3.1正确编写方式

几排保龄球的数量
第一排 = 第二排+3
第二排 = 第三排+3
第三排 = 第四排+3
第四排 = 10
函数形式
line_up(4) = list_up(2)+3
line_up(3) = line_up(3)+3
line_up(2) = line_up(4)+3
line_up(1) = 10
def line_up(a):
if a == 1:
return 10
return line_up((a-1))+3
print(line_up(4))
结果:19
结果是由内而外

四.算法之二分法

算法:有效解决办法的各种方法
二分法 : 一定要有先后顺序排列
简单来说就是一大串串数字从中间要某一个值,进行一大串数字的一分为2,然后进行判断左侧还是右侧大小,如果若没有就在重复的切割直到找到你那个值为止

l1 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21]
"""我需要后边还可以继续延伸"""
我需要17
def get_target(l1,target_num):
# 找不到的情况下是不会一直重复下去的
if len(l1) == 0:
print('没有')
return
# 获取中间的索引值(只能为整数)
middle_index = len(l1) // 2
# 判断中间索引值对应数据的大小
if target_num > l1[middle_index]:
# 保留数据的右边
l1_left = l1[middle_index+1:]
# 对右侧进行切割 重复代码 复杂度降低
print(l1_left)
get_target(l1_left, target_num)
elif target_num < l1[middle_index]:
# 保留左侧数据
l1_right = l1[:middle_index]
print(l1_right)
# 重复右侧切割 重复代码 再次降低复杂
get_target(l1_right, target_num)
else:
print('找到了', target_num)
get_target(l1,17)
结果是:
[12, 13, 14, 15, 16, 17, 18, 19, 20, 21]
找到了 17

python函数基础算法简介的更多相关文章

  1. 《转》Python学习(17)-python函数基础部分

    http://www.cnblogs.com/BeginMan/p/3171977.html 一.什么是函数.方法.过程 推荐阅读:http://www.cnblogs.com/snandy/arch ...

  2. python函数基础学习

    函数的定义与调用: def 函数名(参数1,参数2): ‘’’函数注释’’’ print(‘函数体’) return 返回值 定  义:def关键字开关,空格之后接函数名和圆括号,最后冒号结尾 def ...

  3. Python 函数基础、有序集合、文件操作(三)

    一.set 特点: set是一个无序且不重复的元素集合访问速度快:天生解决元素重复问题 方法: 初始化 >>> s1 = set()>>> print(type(s ...

  4. 10分钟学会Python函数基础知识

    看完本文大概需要8分钟,看完后,仔细看下代码,认真回一下,函数基本知识就OK了.最好还是把代码敲一下. 一.函数基础 简单地说,一个函数就是一组Python语句的组合,它们可以在程序中运行一次或多次运 ...

  5. Python函数基础和函数参数

    函数的定义和函数的调用 return的作用 三种参数的定义 常用的内置函数 len() 函数基础 函数的定义 def 函数名(参数): pass return 表达式 pass在这里表示什么都没有,不 ...

  6. python函数基础

    一.基础 函数的定义 def 函数名(参数): ... 函数体 ... 返回值 #如果函数执行完毕也没有return语句时,自动return None. 空函数 如果想定义一个什么事也不做的空函数,可 ...

  7. python 函数基础介绍

    函数是对程序逻辑进行结构化或过程化的一种编程方法.能将整块代码巧妙地隔离成易于管理的小块,把重复代码放在函数中而不是进行大量的拷贝. 一.函数创建 def 函数创建格式如下: def function ...

  8. 4.python函数基础

    一.函数 1.函数简介 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但 ...

  9. Python函数基础学习(定义、函数参数、递归函数)

    1.本程序是测试函数的基础.函数的参数.递归函数的测试. 函数的参数有: 必选参数.默认参数.可变参数.命名关键字参数和关键字参数 #!/usr/bin/python # -*- coding: ut ...

随机推荐

  1. Java学习笔记:02面向对象-重写_this_super_抽象类

    02面向对象-重写/this/super/抽象类 ****1.this和super 作用: this: 区分本类的成员变量和局部变量同名情况 super:区分父类的成员变量和局部变量同名情况 用法: ...

  2. java-快捷操作

    crtl+c crtl+v crtl+a crtl+x crtl+x剪切 crtl+z撤销 crtl+s保存 alt+f4关闭窗口 完全删除shift+delet widow+r运行程序 window ...

  3. kubernetes内yaml格式

    yaml格式的pod定义文件完整内容: apiVersion: v1 #必选,版本号,例如v1 可通过 kubectl api-versions 获取 kind: Pod #必选,Pod metada ...

  4. Linux移植到自己的开发板(三)根文件系统

    @ 目录 1 Linux内核配置 2 ramdisk制作 3 busybox配置 4 genext2fs生成镜像 为了快速调试,采用ramdisk进行根文件系统测试.要使内核能挂载ramdisk根文件 ...

  5. 面向对象编程(C++篇4)——RAII

    目录 1. 概述 2. 详论 2.1. 堆.栈.静态区 2.2. 手动管理资源的弊端 2.3. 间接使用 2.4. 自下而上的抽象 3. 总结 4. 参考 1. 概述 在前面两篇文章<面向对象编 ...

  6. 教你识别一些sequence的相关问题

    摘要:通过一些自定义的视图或者查询语句,批量识别集群的sequence相关问题 本文分享自华为云社区<GaussDB(DWS)运维 -- sequence常见运维操作>,作者: 譡里个檔. ...

  7. python爬虫 Selenium库学习

    一.自动化测试工具,支持多种浏览器,解决JS渲染问题 二.安装 pip3 install Selenium 三.操作介绍(因为是学习别人的课程为了尊重知识产权,部分代码就不显示了) 1驱动浏览器 br ...

  8. javascript的比较运算符

    JavaScript一共提供了8个比较运算符: > 大于运算符 < 小于运算符 <= 小于等于运算符 >= 大于等于运算符 == 相等运算符 === 严格相等运算符 != 不相 ...

  9. Delete、truncate、drop都是删除语句,它们有什么分别?

    delete 属于DML语句,删除数据,保留表结构,需要commit,可以回滚,如果数据量大,很慢. truncate 属于DDL语句,删除所有数据,保留表结构,自动commit,不可以回滚,一次全部 ...

  10. synchronized、volatile、CAS 比较?

    1.synchronized 是悲观锁,属于抢占式,会引起其他线程阻塞. 2.volatile 提供多线程共享变量可见性和禁止指令重排序优化. 3.CAS 是基于冲突检测的乐观锁(非阻塞)