.匿名函数(名字统一叫lambda)
.语法 lambda 参数:返回值
.参数可以有多个,用逗号隔开
.只能写一行,执行结束后直接返回值
4返回值和正常函数一样,可以是任意值
.列:
f=lambda n:n**n #传入一个数n,返回她的n次方
print(f())
.sorted 排序函数
.语法:
sorted(iteble,key=NONE,reverse=FALSE)
.iteble 可迭代对象
.key 排序函数 sorted内部把可迭代对象的每一个元素传给函数,
根据函数的运算规则(返回值)进行排序
.是否倒叙 TRUE:倒叙 FALSE :正序
4.排序后是一个列表
.列:
.对字典进行排序,返回的是key
dic = {:'A', :'C', :'B'}
print(sorted(dic))
[, , ]
     .列表
lst = [,,,,]
lst2 = sorted(lst)
print(lst) 原列表不会改变
print(lst2) 新列表是经过排序的
.和函数联用
lst = ["麻花藤", "冈本次郎", "中央情报局", "狐仙"]
print(sorted(lst,lambda s:len(s)) 根据字符串长度进行排序
.
lst = [{"id":, "name":'alex', "age":},
{"id":, "name":'wusir', "age":},
{"id":, "name":'taibai', "age":}]
print(sorted(lst,lambda s:s["age"]) 根据年龄排序字典
.filter 筛选函数
.语法
filter(function,iterble)
用来筛选的函数,filter会自动把可迭代对象的元素传给
function,然后根据function返回的TRUE 或者FALSE来
判断是否保留此项数据
.列
lst = [,,,,,,]
ll=print(lambda i:i%==,lst)#筛选出所有偶数
print(ll) #迭代器
print(list(ll)) #取值[, , ]
.
lst = [{"id":, "name":'alex', "age":},
{"id":, "name":'wusir', "age":},
{"id":, "name":'taibai', "age":}]
fl = filter(lambda e: e['age'] > , lst) # 筛选年龄⼤于16的数据
print(list(fl))
.map 映射函数
.语法
map(function,iteable)
.求平方
print(list(map(lambda x:x*x*x,[,,,,])))
.映射
lis1=[,,,,]
lis2=[,,,,]
map(lambda x,y:x+y,lis1,lis2)
注: . 如果lis不等长,就是按短的截取
.如果函数不存在,就一一对应打包成元组
 注:map和filter返回的都是迭代器,所以要看里面的内容需要用for循环查询出来,或者将返回值直接转换成列表
.递归
.定义:在函数中调用函数本身就是递归
.语法
def func()
print("递归")
func()
func()
.应用 遍历文件夹的所有文件
import os
def read(filepath,n)
list=os.listdir(filepath) #打开一个文件,获取里面所有的内容,返回列表
for fi in list: #遍历获得的名字(包含文件名和文件夹名)
file_real_path=os.path.join(path,fi) #获得的名字加上路径等于绝对路径
if os.path.isdir(file_real_path) #判断在绝对路径下是否文件夹
#递归的入口
print("\t"*n,fi) #打印
read(file_real_path,n+1) #是文件夹继续调用函数
else:
print("\t"*n,fi) #不是文件夹就直接输出
read("../py",)
.二分法
.优点:查找快,效率高
.缺点:局限性大,必须是有序序列
.列
lst = [, , , , , , , , , , , , , , ]
num=int(input("请输入要查找的数字"))
left= #确定左边界,其实是索引的起始
right=len(lst)- #确定右边界,其实是索引的结束
count=1 #用来确定共查找了几次
while left<=right:
mid=(left+right)//2 #整除2 ,取整
if num>lst[mid]:
left=mid+
elif num<lst[mid]:
right=mid-
else:
print("找到了")
break
count+=1
else:
print("没找到")
7.普通版的二分法(函数的方法)
lst=[...........]
def binary_search(n,left,right) #查找的数以及左右边界()
if left<right:
mid=(left+right)//2 #对2整除,取整
if n<lst[mid]:
right=mid-1
elif n>lst[mid]:
left=mid+1
else:
return mid
return binary_search(n,left,right) #这个return一定要加,要不然返回的一定是NONE
else:
return -1
print(binary_search(567, 0, len(lst)-1))
8.另类二分法,比较难计算位置
lst=[.......]
def binary_search(ls,target):
left=0
right=len(lst)-1
if left>right:
print("不存在")
mid=(left+right)//2
if target<lst[mid]
return binary_search(lst[:mid],target)
elif target>lst[mid]
return binary_search(lst[mid+1:],target)
else:
print("在这里")
binary_search(lst.,567)

day13 内置函数二 递归,匿名函数,二分法的更多相关文章

  1. Python内置函数二 (递归函数,匿名函数,二分法)

    匿名函数 lambda() 语法: lambad  参数 : 返回值 def func(a,b): return a * b print(func(2,5)) a = lambda a ,b : a* ...

  2. python之内置函数(二)与匿名函数、递归函数初识

    一.内置函数(二)1.和数据结构相关(24)列表和元祖(2)list:将一个可迭代对象转化成列表(如果是字典,默认将key作为列表的元素).tuple:将一个可迭代对象转化成元组(如果是字典,默认将k ...

  3. python函数知识六 内置函数二、匿名函数与内置函数三(重要)

    19.内置函数二 abs():绝对值 lst = [1,2,-3,1,2,-5] print([abs(i) for i in lst]) enumerate("可迭代对象",&q ...

  4. Python之旅Day3 文件操作 函数(递归|匿名|嵌套|高阶)函数式编程 内置方法

    知识回顾 常见五大数据类型分类小结:数字.字符串.列表.元组.字典 按存值个数区分:容器类型(列表.字典.元组) 标量原子(数字.字符串) 按是否可变区分:可变(列表.字典) 不可变(数字.字符串.元 ...

  5. 《Python》 内置函数补充、匿名函数、递归初识

    一.内置函数补充: 1.数据结构相关(24): 列表和元祖(2):list.tuple list:将一个可迭代对象转化成列表(如果是字典,默认将key作为列表的元素). tuple:将一个可迭代对象转 ...

  6. python学习-day16:函数作用域、匿名函数、函数式编程、map、filter、reduce函数、内置函数r

    一.作用域 作用域在定义函数时就已经固定住了,不会随着调用位置的改变而改变 二.匿名函数 lambda:正常和其他函数进行配合使用.正常无需把匿名函数赋值给一个变量. f=lambda x:x*x p ...

  7. 内置函数filter()和匿名函数lambda解析

    一.内置函数filter filter()函数是 Python 内置的一个高阶函数,filter()函数接收一个函数 f 和一个list,这个函数 f 的作用是对每个元素进行判断,返回由符合条件迭代器 ...

  8. day16_函数作用域_匿名函数_函数式编程_map_reduce_filter_(部分)内置函数

    20180729    补充部分代码 20180727    上传代码 #!/usr/bin/env python # -*- coding:utf-8 -*- # ***************** ...

  9. JavaScript 闭包系列二(匿名函数及函数的闭包)

    一. 匿名函数 1. 函数的定义,可分为三种 1) 函数声明方式 function double(x) {     return 2*x; } 2)Function构造函数,把参数列表和函数体都作为字 ...

随机推荐

  1. cfree使用cygwin编译程序出现计算机丢失cygwin1.dll解决办法

    这种情况多是环境没配好,我的是64位cygwin C:\cygwin64\bin 加入到环境变量中,重打开cfree就可以解决.

  2. Hbuilder实用技巧(转)

    Hbuilder实用技巧 原创 2016年05月19日 10:25:42 标签: hbuilder 操作 16551 1. Q:怎么实现代码追踪? A:在编辑代码时经常会出现需要跳转到引用文件或者变量 ...

  3. JavaScript基础笔记集合(转)

    JavaScript基础笔记集合   JavaScript基础笔记集合   js简介 js是脚本语言.浏览器是逐行的读取代码,而传统编程会在执行前进行编译   js存放的位置 html脚本必须放在&l ...

  4. ROS Learning-013 beginner_Tutorials (编程) 编写ROS服务版的Hello World程序(Python版)

    ROS Indigo beginner_Tutorials-12 编写ROS服务版的Hello World程序(Python版) 我使用的虚拟机软件:VMware Workstation 11 使用的 ...

  5. python的argparse模块

    一.简介: argparse是python用于解析命令行参数和选项的标准模块,用于代替已经过时的optparse模块.argparse模块的作用是用于解析命令行参数,例如python parseTes ...

  6. UVA1723 Intervals

    这题$n$倍经验…… 考虑差分约束: 我们设$s_i$表示$[-1, i]$这个区间中数字的种类数,那么一个条件的限制相当于$s_{b_i} - s_{a_i - 1} \leq c_i$,那么连边$ ...

  7. DotNet经典面试题(转载)

    .Net基础常见 什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS.CLS.CLR分别作何解释? 答: 1应用程序域可以理解为一种轻量级进程.起到安全的作用 ...

  8. linux文件链接

    我的github,欢迎关注,分享知识与技术 链接:一种在共享文件和访问它的用户的若干目录项之间建立联系的一种方法. Linux中包括两种链接:硬链接(HardLink)和软链接(Soft Link), ...

  9. jmeter 阶梯式加压测试

    性能测试中,有时需要模拟一种实际生产中经常出现的情况,即:从某个值开始不断增加压力,直至达到某个值,然后持续运行一段时间. 在jmeter中,有这样一个插件,可以帮我们实现这个功能,这个插件就是:St ...

  10. XCode9: iPhone is busy: Preparing debugger support for iPhone

    这个好像是等一阵子就可以了 参考链接