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

问题描述

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

输入:

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)更易读,因为这对我来说有点“神奇”。