疯狂的python设置

时间:2011-09-16 14:27:35

标签: python set

请查看ipython的以下片段:

In [122]: len(netean)
Out[122]: 150

In [123]: len(nwrongpea)
Out[123]: 100

In [124]: len(set.intersection(set(nwrongpea), set(netean)))
Out[124]: 8

In [125]: len(set(nwrongpea) - set(netean))
Out[125]: 90

In [126]: len(set(netean) - set(nwrongpea))
Out[126]: 142

我疯了 - 因为这两个列表有8个共同的元素(基于交叉点的答案),[125]如何返回90?不应该是92?

我是否忘记了集理论中的某些东西?

谢谢!

1 个答案:

答案 0 :(得分:10)

看起来这个集合中有一个(或两个)有一些重复的元素。因此,从它们创建集合可以为您提供具有较少元素的集合。

试试len(set(natean)) + len(set(nwrongpea)),您会看到。