微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

仅包含两个归因列表之间共有的元素的列表如果没有重复,我将无法做到

如何解决仅包含两个归因列表之间共有的元素的列表如果没有重复,我将无法做到

从两个列表中返回一个列表,该列表仅包含两个输入列表之间共有的元素。 没有重复。

输入:

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 举报,一经查实,本站将立刻删除。