乐学python怎么样_铁乐学python_day09_作业

练习题

1、整理函数相关知识点,写博客 2、写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素, 并将其作为新列表返回给调用者。 def odd_index(l): lis = [] for i in range(len(l)): # 通过range设定索引范围比通过元素找索引要好,因为相同元素返回的索引值会有误 if i % 2 != 0: lis.append(l[i]) return lis # 验证odd_index函数的使用正常不: li = [ i for i in range(20)] print(li) print(odd_index(li)) tuple1 = ('a', 'b', 'c', 'b', 'c', 'd', 'e', 'f', 'g') print(odd_index(tuple1)) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19] [1, 3, 5, 7, 9, 11, 13, 15, 17, 19] ['b', 'b', 'd', 'f'] # 利用切片会更简单 # def odd_index(argv): # return argv[1::2] 3、写函数,判断用户传入的对象(字符串、列表、元组)长度是否大于5。 def len_5(l): return len(l) > 5 4、写函数,检查传入列表的长度,如果大于2,那么仅保留前两个长度的内容, 并将新内容返回给调用者。 def len_2(l): if len(l) > 2: # 满足条件才返回内容,不满足的话就什么也不做,也就是None return l[:2] lis = [1, 2] print(len_2(lis)) lis2 = [1, 2, 3, 4] print(len_2(lis2)) None [1, 2] 5、写函数,计算传入字符串中【数字】、【字母】、【空格] 以及 【其他】的个数,并返回结果。 def count_n(s): num = 0 alpha = 0 blank = 0 other = 0 for i in s: if i.isdigit(): num += 1 elif i.isalpha(): alpha += 1 elif i == ' ': blank += 1 else: other += 1 result = '共有数字{}个,字母{}个,空格{}个,其他{}个'.format(num,alpha,blank,other) return(result) # 验证 print(count_n('uy143 oifg87 90/+ ')) 共有数字7个,字母6个,空格6个,其他2个 6、写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否含有空内容2,并返回结果。 def blank_ex(l): li = [] for i in l: if ' ' in str(i): li.append(i) return li #验证 s = 'yiu dgh' li1 = [' 34s', 45, 'et'] tuple1 = ( 'r t', 78, [ ]) print(blank_ex(s)) print(blank_ex(li1)) print(blank_ex(tuple1)) 7、写函数,检查传入字典的每一个value的长度,如果大于2, 那么仅保留前两个长度的内容,并将新内容返回给调用者。 dic = {"k1": "v1v1", "k2": [11,22,33,44]} PS:字典中的value只能是字符串或列表 def dic_ex(d): for i in d: # 通过键来找到相应的值,可以直接重新赋值 if len(d[i]) > 2: d[i] = d[i][:2] return d # 验证 dic = {"k1": "v1v1", "k2": [11,22,33,44],} print(dic_ex(dic)) {'k1': 'v1', 'k2': [11, 22]} 8、写函数,接收两个数字参数,返回比较大的那个数字。 def max_min(a, b): return a if a > b else b 9、写函数,用户传入修改的文件名,与要修改的内容, 执行函数,完成整个文件的批量修改操作(进阶)。 10、写一个函数完成三次登陆功能,再写一个函数完成注册功能(进阶) # 定义注册函数 def register(*args, **kwargs): while True: username = input('请输入用户名(Q/q返回首页):').strip() if username.upper() == 'Q': # 退出函数 return with open('reg.txt', encoding='utf-8') as f1: for i in f1: user = i.strip().split() if username == user[0] or username == '': print('己存在用户名,请重新注册:') break # 在for循环读取完整个文件判断没有同名用户后才进行追加写入的操作 else: password = input('请输入密码:').strip() # 扩展了一个密码不能为空和小于6位数的功能 if password =='' or len(password) < 6: print('密码不能为空或小于6位,请重新注册。') continue with open('reg.txt', encoding='utf-8', mode='a') as f2: f2.write('\n{}\t{}'.format(username, password)) print('注册成功') return # 定义一个登录函数 def login(*args, **kwargs): count = 3 while count != 0: username = input('请输入你的用户名:').strip() password = input('请输入你的密码:').strip() with open('reg.txt', encoding='utf-8') as f3: for i in f3: user = i.strip().split() if username == user[0] and password == user[1]: print('登录成功') # 登录成功退出登录函数 return else: count -= 1 print('你的用户名或密码输入错误,请重新输入。你还有%d次机会。' % count) print('你的三次输入机会己用尽,请稍后再试。') 明日默写。 ①,return的作用。 ②,传参的几种方法,每个都简单写一个代码。 如,实参,按位置传参。 def func(x,y): Pass func(‘a’,’b’)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
代码下载:完整代码,可直接运行 ;运行版本:2022a或2019b或2014a;若运行有问题,可私信博主; **仿真咨询 1 各类智能优化算法改进及应用** 生产调度、经济调度、装配线调度、充电优化、车间调度、发车优化、水库调度、三维装箱、物流选址、货位优化、公交排班优化、充电桩布局优化、车间布局优化、集装箱船配载优化、水泵组合优化、解医疗资源分配优化、设施布局优化、可视域基站和无人机选址优化 **2 机器学习和深度学习方面** 卷积神经网络(CNN)、LSTM、支持向量机(SVM)、最小二乘支持向量机(LSSVM)、极限学习机(ELM)、核极限学习机(KELM)、BP、RBF、宽度学习、DBN、RF、RBF、DELM、XGBOOST、TCN实现风电预测、光伏预测、电池寿命预测、辐射源识别、交通流预测、负荷预测、股价预测、PM2.5浓度预测、电池健康状态预测、水体光学参数反演、NLOS信号识别、地铁停车精准预测、变压器故障诊断 **3 图像处理方面** 图像识别、图像分割、图像检测、图像隐藏、图像配准、图像拼接、图像融合、图像增强、图像压缩感知 **4 路径规划方面** 旅行商问题(TSP)、车辆路径问题(VRP、MVRP、CVRP、VRPTW等)、无人机三维路径规划、无人机协同、无人机编队、机器人路径规划、栅格地图路径规划、多式联运运输问题、车辆协同无人机路径规划、天线线性阵列分布优化、车间布局优化 **5 无人机应用方面** 无人机路径规划、无人机控制、无人机编队、无人机协同、无人机任务分配 **6 无线传感器定位及布局方面** 传感器部署优化、通信协议优化、路由优化、目标定位优化、Dv-Hop定位优化、Leach协议优化、WSN覆盖优化、组播优化、RSSI定位优化 **7 信号处理方面** 信号识别、信号加密、信号去噪、信号增强、雷达信号处理、信号水印嵌入提取、肌电信号、脑电信号、信号配时优化 **8 电力系统方面** 微电网优化、无功优化、配电网重构、储能配置 **9 元胞自动机方面** 交通流 人群疏散 病毒扩散 晶体生长 **10 雷达方面** 卡尔曼滤波跟踪、航迹关联、航迹融合

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值