首页 > 其他 > 详细

递归,二分法,lambda,filter,map,sorted

时间:2018-08-15 18:15:05      阅读:143      评论:0      收藏:0      [点我收藏+]

匿名函数(lamda) 

为及解决简单的一些需求而设计的一句话函数

函数名 = lamba参数:返回值
f = lambda n: n*n 求n的n次方 print(f(9))

注意

函数 的参数可以有多个,多个参数之间用逗号,隔开.

匿名函数不管有多复杂,只能写一行,且逻辑结束后直接返回数据

返回值和正常的数据一样,可以是任意数据类型

小注意点

匿名函数之所以叫匿名函数是因为我们通过__name__查看的时候,是没有名字的统一交lamda,

正常函数调用查看名字
def func(n):
    return n*n
print(func.__name__)    #func

与__doc__     差不多

二,sorted函数   (有返回值)

排序函数   sorted(iterable, key = mone, reverse = False)

key:  排序规则(排序函数),在sorted内部会将可迭代对象中的每一个元素传递给这个函数的参数,根据函数运算的结果进行排序.

reverse:默认是升序,reverse = True  是降序

lst = [23,4,12,3,7]
lst_new = sorted(lst)
print(lst)
print(lst_new)
# 和函数搭配使用 lst
= [23,4,12,3,7] def func(n): return n % 2 s = sorted(lst,key = func) print(s)

# 根据字符串串?长度进?行行排序
lst = ["麻花藤", "冈本次郎", "中央情报局", "狐仙"]
# 计算字符串串?长度
def func(s):
return len(s)
print(sorted(lst, key=func))

# 和lambda搭配使用
lst = [23,4,12,3,7]
s = sorted(lst,key = lambda n :n + 1)
print(s)

三 filter 函数

筛选函数  filter(function,literable)

function: 用来筛选函数,在filter函数中自动的八iterable中的元素传递给function,然后根据function返回的True或者是 False来判断是否保留此项数据

ll = [23,4,12,3,7]
s = filter(lambda x: x % 2 == 0,ll)
print(s)  #得到的是筛选对象 <filter object at 0x0046FE10>
print(list(s))  #[4, 12]

lst = [{"id":1, "name":‘alex‘, "age":18},
{"id":2, "name":‘wusir‘, "age":16},
{"id":3, "name":‘taibai‘, "age":17}]
s = filter(lambda x: x["age"] >16,lst)
print(s)#<filter object at 0x002D0A10>
print(list(s))#[{‘id‘: 1, ‘name‘: ‘alex‘, ‘age‘: 18}, {‘id‘: 3, ‘name‘: ‘taibai‘, ‘age‘: 17}]

四 map

映射函数    map(function,literable)可以对可迭代对象的每一个元素进行映射,分别取执行function

# def func(n):
#     return n*n
# lst = [1,3,45,2]
# s = map(func,lst)
# print(s)#<map object at 0x001EF970>
# print(list(s))#[1, 9, 2025, 4]

# 与lambda使用
lst= [1,2,3,1,78]
s = map(lambda x:x*x,lst)
print(list(s))


# 计算两个列表中相同位置的数据的和  有水桶效应(map)
lst1 = [1,3,5,7,3,23,54]
lst2 = [34,7,8,45,9,22,3,33]
s = map(lambda x,y:x + y ,lst1,lst2)
print(list(s)) #[35, 10, 13, 52, 12, 45, 57]

五 递归

在函数中调用函数本身,就是递归,在Python中递归的最大深度就是1000,其实不到1000就会报错

def func():
    print("小仙女")
    func()
func()

def foo(n):
print(n)
n += 1
foo(n)
foo(1)

递归的应用:  递归用return 出口

我们可以用递归来遍历各种树形结构,比如我们的文件系统,可以使用递归来遍历该文件夹中的所有文件

import os
def read(filepath, n):
files = os.listdir(filepath) # 获取到当前文件夹中的所有?文件
for fi in files: # 遍历?文件夹中的?文件, 这里里获取的是本层文件名
fi_d = os.path.join(filepath,fi) # 加入文件夹 获取到文件夹+文件
if os.path.isdir(fi_d): # 如果该路路径下的文件是文件夹
print("\t"*n, fi)
read(fi_d, n+1) # 继续进?行行相同的操作
else:
print("\t"*n, fi) # 递归出口. 最终在这里里隐含着return
#递归遍历?目录下所有?文件
read(../oldboy/, 0)

六 二分查找

每次能够砍掉一半的数据,查找效率非常高,但是只有有序的序列才能用

lst = [2, 3, 4, 5, 6, 7, 8, 9, 12, 45, 90, 95,112,134]
def func(left ,right,n):
if left <= right:
mid = (left + right) // 2 #中间索引位置
if n > lst[mid]:
left = mid +1
return func(left ,right,n)
elif n < lst[mid]:
right = mid -1
return func(left ,right,n)
else:
print("找到了")
return mid 找到返回索引,那么上面的都要加上return在调用
    ###return func(left ,right,n)
    else:
print("mei")
return -1 #找不到返回-1
ret = func(0,len(lst)-1,77)
print(ret)
注意  也可以将下面绿色的部分只写一次,放在我标注的上面代码我标注绿色的地方
return func(left ,right,n)
============================================================
普通版本
n = 8
# lst = [2, 3, 4, 5, 6, 7, 8, 9, 12, 45, 90, 95,112,134]
# left = 0
# right = len(lst) -1
# while left <= right:
# mid = (left + right)
# if n > lst[mid]:
# left += 1
# continue
# elif n < lst[mid]:
# right -= 1
# continue
# else:
# print("找到了")
# break
# else:
# print("mei")

另类的二分法

def binary_search(ls, target):
    left = 0
    right = len(ls) - 1
    if left > right:
        print("不在这里")
    middle = (left + right) // 2
    if target < ls[middle]:
        return binary_search(ls[:middle], target)
    elif target > ls[middle]:
        return binary_search(ls[middle+1:], target)
    else:
        print("在这里")
binary_search(lst, 567)

 

递归,二分法,lambda,filter,map,sorted

原文:https://www.cnblogs.com/lxx7/p/9482987.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!