Python列表问题

本文介绍了一种使用Python列表推导式来实现两个列表元素匹配计数的方法。具体来说,对于列表A中的每个子列表,遍历其内部元素,并在列表B中查找这些元素出现的次数。最终生成了一个新的矩阵C,该矩阵记录了每个子列表内元素在列表B中的出现频率。

有两个列表A,B

A = [[[3, 5], [0, 2], [2, 10]], [[6, 9], [7, 2], [9, 7]], [[3, 3], [5, 3], [10, 2]]];

B = [[0, 2], [2, 10], [3, 3]]; 

如何得到[[0, 1, 1], [0, 0, 0], [1, 0, 0]]?

求解:

>>> A = [[[3, 5], [0, 2], [2, 10]], [[6, 9], [7, 2], [9, 7]], [[3, 3], [5, 3], [10, 2]]]
>>> B = [[0, 2], [2, 10], [3, 3]]
>>> C = [[B.count(x) for x in y] for y in A]
>>> C
[[0, 1, 1], [0, 0, 0], [1, 0, 0]]

 

转载于:https://www.cnblogs.com/fortwo/archive/2013/04/22/3036705.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值