Python每日一练0030

问题

如何判断一个list包含另一个list

例如我有两个list

List1 = ['a','c','c']
List2 = ['x','b','a','x','c','y','c']

如何判断list2包含了list1

解决方案

如果元素的数量不重要,也就是说只判断list1里的所有种类在list2都有出现过,那么使用set()即可

>>> List1 = ['a','c','c']
>>> List2 = ['x','b','a','x','c','y','c']
>>> set(List1) < set(List2)
True

如果元素的数量也需要考虑,即list1里的元素必须全部在list2里出现并且不重复,那么可以考虑使用Counter

from collections import Counter

def counterSubset(list1, list2):
    counter1 = Counter(list1)
    counter2 = Counter(list2)
    for k, v in counter1.items():
        if v > counter2[k]:
            return False
    return True

List1 = ['a', 'c', 'c']
List2 = ['x', 'b', 'a', 'x', 'c', 'y', 'c']
print(counterSubset(List1, List2))

我们还可以使用all()来简化代码

>>> from collections import Counter
>>> List1 = ['a', 'c', 'c']
>>> List2 = ['x', 'b', 'a', 'x', 'c', 'y', 'c']
>>> counter1 = Counter(List1)
>>> counter2 = Counter(List2)
>>> print(all(v <= counter2[k] for k, v in counter1.items()))
True

讨论

对于set类型,Python提供了一些操作符来描述两个集合的关系(包含、真包含等等)。而<操作符描述的是,一个集合是否是另一个集合的真子集

all()接受一个可迭代对象作为参数,并且判断这个可迭代对象的所有元素是否全部为True。相应的,还有any() 函数,用来判断是否存在一个True

来源

Stack Overflow

关注

欢迎关注我的微信公众号:python每日一练

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值