如何解决仅包含两个归因列表之间共有的元素的列表如果没有重复,我将无法做到
从两个列表中返回一个列表,该列表仅包含两个输入列表之间共有的元素。 没有重复。
输入:
a = [1,1,2,3,5,8,13,21,34,55,89]
b = [1,4,6,7,9,10,11,12,13]
我的解决方案:
common_list = [i for i in a if i in b]
我的输出:
[1,13]
我需要的输出:
[1,13]
解决方法
您可以使用设置操作
In [13]: a = [1,1,2,3,5,8,13,21,34,55,89]
...: b = [1,4,6,7,9,10,11,12,13]
In [14]: list(set(a) & set(b))
Out[14]: [1,13]
代码的问题是输出中的重复元素。您可以通过在输出上应用set运算符来避免这种情况
common_list = list(set(i for i in a if i in b))
,
您可以使用设置交集:
a = [1,89]
b = [1,13]
out = list(set(a).intersection(set(b)))
print(out)
输出:
[1,13]
,
作为Arun答案的替代方法,您还可以执行以下操作:
a = [1,13]
set(a).intersection(b)
我觉得比set(a) & set(b)
更易读,因为这对我来说有点“神奇”。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。