python进阶之路13 二分法 三元表达式 各种生成式 匿名函数
算法简介及二分法
1.什么是算法
算法就是解决问题的有效方法 不是所有的算法都很高效也有不合格的算法
2.算法应用场景
推荐算法(抖音视频推送 淘宝商品推送)
成像算法(AI相关)......
几乎涵盖了我们日常生活中的方方面面
3.算法工程师要求
待遇非常好 但是要求也非常高
4.算法部门
不是所有的互联网公司都养得起算法部门 只有大型互联网公司才有
算法部门类似于药品研发部门
5.二分法
是算法中最简单的算法 甚至都称不上是算法
"""
二分法使用要求
待查找的数据集必须有序
二分法缺陷
针对开头结尾的数据 查找效率很低
常见算法的原理以及伪代码
二分法、冒泡、快排、插入、堆排、统排、数据结构(链表 约瑟夫问题 如何链表是否成环
"""
查找列表中某个数据值
# 方式1:for循环 次数较多
# 方式2:二分法 不断的对数据集做二分切割
'''代码实现二分法'''
l1 = [12, 21, 32, 43, 56, 76, 87, 98, 123, 321, 453, 565, 678, 754, 812, 987, 1001, 1232]
def get_middle(l1, target_num):
# 添加一个具体的结束条件
if len(l1) == 0:
print('很抱歉 没找到')
return
# 1.获取列表中的索引值
middle_index = len(l1) // 2
# 2.比较目标数据值与中间索引值的大小
if target_num > l1[middle_index]:
# 切片保留列表右边一半
right_l1= l1[middle_index + 1 :]
print(right_l1)
# 针对右边一般的列表继续二分并判断
return get_middle(right_l1, target_num)
if target_num < l1[middle_index]:
# 切片保留列表左边一半
lift_l1 = l1[:middle_index]
print(lift_l1)
# 针对左边一般的列表继续二分并判断
return get_middle(lift_l1,target_num)
else:
print('恭喜你 找到了')
# get_middle(l1,987)
get_middle(l1,10000)
三元表达式
# 简化步骤1: 代码简单并且只有一行 那么可以直接在冒号后面编写
name = 'jason'
# if name == 'jason':print('老师')
# else:print('学生')
# 三元表达式
res = '老师' if name == 'jason' else '学生'
print(res)
"""
数据值1 if 条件 else 数据值2
条件成立则使用数据值1 条件不成立则使用数据值2
当结果是二选一的情况下 使用三元表达式较为简便
并且不推荐多个三元表达式嵌套
"""
各种生成式/表达式/推导式
name_list = ['jason', 'kevin','oscar','tony','jerry']
# 给列表中所有人名的后面加上_NB的后缀
# for 循环
# new_list = []
# for name in name_list:
# data = f'{name}_NB'
# new_list.append(data)
# print(new_list)
# 列表生成式
# new_list = [name + '_NB' for name in name_list]
# print(new_list)
# 复杂情况
new_list = [name + '_NB' for name in name_list if name == 'jason']
print(new_list)
new_list = ['大佬' if name == 'jason' else '小赤佬' for name in name_list if name != 'berk']
print(new_list)
# 字典生成式
# s1 = 'hello'
# for i,j in enumerate(s1):
# print(i, j)
d1 = {i:j for i , j in enumerate('hello')}
print(d1) # {0: 'h', 1: 'e', 2: 'l', 3: 'l', 4: 'o'}
# 集合生成式
res = {i for i in 'hello'}
print(res)
# 元组没有生成式: 下列的结果是生成器
res = (i+'sb' for i in 'hello')
print(res)
for i in res:
print(i)
匿名函数
没有名字的函数 需要使用关键字lambda
语法结构
lambda 形参:返回值
使用场景
lambda a, b :a+b
匿名函数一般不单独使用 需要配合其他函数一起用
昨天作业
1.利用递归函数依次打印列表中每一个数据值
l1 = [1, [2, [3, [4, [5, [6, [7, [8, ]]]]]]]]
# 方法1:胡
def print_item(l):
print(l[0])
if len(l) == 1:
return l[0]
return print_item(l[1])
print_item(l1)
# 方法2:老师讲
print(isinstance(123,int)) # 判断第一个数据值是不是属于第二个参数指定的数据类型 True
print(isinstance(123,str)) # 判断第一个数据值是不是属于第二个参数指定的数据类型 False
def get_num(l1):
for i in l1:
if isinstance(i, int):
print(i)
else:
return get_num(i)
get_num(l1)
2.利用有参装饰器编写多种用户登录校验策略
def login_auth(condition):
def outer(func_name):
def inner(*args,**kwargs):
# 获取用户名和密码
username = input('please input your username>>>:').strip()
password = input('please input your password>>>:').strip()
# 判断校验的策略
if condition == 'absolute':
if username == 'jason' and password == '123':
res = func_name(*args, **kwargs)
return res
else:
print('用户名和密码错误')
elif condition == 'list_type':
user_list = ['jason|123', 'tony|321', 'kevin|222']
user_data = f'{username}|{password}'
if user_data in user_list:
res = func_name(*args, **kwargs)
return res
else:
print('用户名和密码错误')
elif condition == 'file_type':
# 这里是一个文件 创建一个userinfo.txt的文本文件 里面分行填写jason|123, tony|321,kevin|222
with open(r'userinfo.txt','r',encoding='utf8')as f:
for line in f:
real_name, real_pwd = line.split('|')
if real_name == username and real_pwd.strip('\n') == password:
res = func_name(*args, **kwargs)
return res
return inner
return outer
@login_auth('absolute')
def index(*args,**kwargs):
print('form index')
@login_auth('list_type')
def func(*args,**kwargs):
print('from func')
@login_auth('file_type')
def func1(*args,**kwargs):
print('from func1')
index()
func()
func1()