Python之旅Week 1 Day 1

日记部分:
现在是中午12:30左右,下午有一个比赛,作品没做出来,让去答辩,拿什么答辩,不行就直接已退赛吧,刚刚调试作品,也没成功,算了,打算一回去了跟负责老师说一下,不行就退赛(现在是凌晨补充一下今天的战况,下午当然是不可能退缩,去了答辩,但是因为没有实物所以老师也很无奈,不管怎么样,继续努力加油吧,争取在以后的日子里不会出现了这样的事情了,说真的下午真的有点儿Diu/Ren了),好了,进入正题:

First of all :在学习笔记中可能会比较啰嗦,或者存在一些错误,还请大家谅解并且指出错误所在,如果错误存在的话,可以互相讨论学习,已达到互相进步的作用,谢谢大神看官们了。
还有本次必刷题使用的IDE是VSCode,环境是Win10,Python3.7.2

本周的主要内容是:数据结构与算法相关问题与解决技巧

Python必刷题之一:

如何在列表、字典、集合中根据条件筛选出数据:

  1. 列表
    过滤掉列表中不符合条件的项:
    例:生成随机列表并过滤掉负数,并输出:
    方法一:迭代法
from random import randint
lists=[randint(-10,10) for x in range(20)]
print(lists)
NewList=[]
for x in lists:
    if x>=0:
        NewList.append(x)
print(NewList)
#输出结果:
[-8, 0, -10, -10, -8, -8, 10, 10, 10, 8, 0, 8, 9, 10, -7, 3, 10, 4, -4, 9]
[0, 10, 10, 10, 8, 0, 8, 9, 10, 3, 10, 4, 9]

方法二:内置函数法

from random import randint
lists=[randint(-10,10) for x in range(20)]
print(lists)
NewList=filter(lambda x:x>0,lists)
print(list(NewList))
#输出结果
[4, 3, 10, 6, -7, 5, -8, -7, 1, -10, -4, -3, 9, -7, -6, -5, -8, -7, -8, -5]
[4, 3, 10, 6, 5, 1, 9]

方法三:列表解析法:

from random import randint
lists=[randint(-10,10) for x in range(20)]
print(lists)
NewList=[x for x in lists if x >=0]
print(NewList)
#输出结果:
[-5, 1, -2, 9, 2, 4, -5, -2, 0, -9, -4, -4, 1, 4, 1, 4, 5, -8, 8, -2]
[1, 9, 2, 4, 0, 1, 4, 1, 4, 5, 8]

在这个题目中,filter过滤器函数,lambda匿名函数,这些都是内置函数,所以如果不是很明白这类函数的同学,恶补一下他们的使用方法。
当然,如果一个问题有多重解决方法的时候,我们就会考虑他们的效率问题。我们使用timeit函数,来对他们的运算时间进行测试列表解析是更好一些,filter比列表解析慢一些,当然这两者都比迭代法更快一些。
首选推荐列表解析法。

  1. 字典
    在字典中筛选出符合条件的元素,并输出:
    这个题的解法类似于列表解析,使用字典解析可以求解:
from random import randint
dicts={x:randint(60,100)for x in range(1,11)}
print(dicts)
NewDicts={k:v for k,v in dicts.items() if v>=90 }
print(NewDicts)
#输出结果:
{1: 94, 2: 62, 3: 93, 4: 67, 5: 69, 6: 75, 7: 78, 8: 60, 9: 95, 10: 61}
{1: 94, 3: 93, 9: 95}

这里的字典解析与上面的方法三类似,只不过这里需要注意字典解析的键与值都需要进行遍历。

  1. 集合
    在集合中进行字段处理:
from random import randint
sets={randint(-10,10) for x in range(10)}
print(sets)
NewSets={x for x in sets if x >= 0}
print(NewSets)
#输出结果:
{3, 5, 8, -9, -7, -5, -4, -2}}——因为是集合所以相同元素会被迭代
{3, -9}

每日小结:

在今天的课中,主要学到了
①随机数的生成函数的用法,在生成不同种的数据的时候需要我们进行变换生成方式,比如说在生成列表或者是集合的时候,我们只需要控制生成的一个变量集合。但是如果,我们要生成字典类型的数据的时候,我们要注意生成的数据的每一个部分是由那个变量控制的;
单独拿出来看一下(以备以后复习的时候用):
列表或者集合生成方式:
lists=[randint(-10,10) for x in range(20)]
sets={randint(-10,10) for x in range(10)}
字典生成方式:
dicts={x:randint(60,100)for x in range(1,11)}
②在各类数据解析的时候,控制解析的条件方法;
③复习了lambda匿名函数与filter过滤函数的使用;
lambda函数中不需要函数名,只需要传入制定的参数与函数执行逻辑。
filter函数中需要传入的第一个参数是执行函数或者是空,第二个参数是数据对象。

如果文章中有错误,请看官们指出来,当然写博客最主要的目的之一是为了能督促我进步,能够每天固定的学习,以至于不让自己退步,优秀的人太多,只有你比优秀的人更努力,更加坚持,才能超越他们。

今天看到学霸兼好朋友说的一句话:我们需要在我们奋斗的路上不断努力、奋进,如果在这条路上你感到累了,证明你正在努力。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值