Python多个交集

时间:2012-05-29 10:18:20

标签: python set intersection

我在python中重新实现了这个集合,但是我遇到了多个交集的问题....我按照学习Python这本书但我的代码有问题

class Set:
    def __init__(self,value=[]):
        self.data = []
        self.remDupli(value)

    def remDupli(self,val):
        for i in val:
            if i not in self.data:
                self.data.append(i)

    def intersect(self,other):
        val=[]
        for i in self.data:
            for k in other:
                if i == k:
                    val.append(i)
        return Set(val)

    def union(self,other):
        val=self.data
        for i in other:
            if i not in self.data:
                val.append(i)
        return Set(val)

    def __or__(self,a):       return self.union(a)
    def __and__(self,a):      return self.intersect(a)
    def __len__(self):        return len(self.data)
    def __getitem__(self,key):  return self.data[key]
    def __repr__(self):       return 'Set: ' +repr(self.data)

class Extend(Set):
    def intersect(self, *others):
        val = []
        for i in self:
            for x in others:
                if i in x:
                    val.append(i)
        return Set(val)

但是当我运行时:

x = Extend([1,2,3,4])
y = Extend([3,4,5])
z = Extend([0,1,2])
print(x & y & z)
print(x.intersect(y, z))

我有两种不同的行为

Set: []
Set: [1, 2, 3, 4]

我不明白,因为第二个是不同的,在我看来他们应该有相同的行为,任何人都可以帮助我?

1 个答案:

答案 0 :(得分:6)

Extend.intersect不计算多个集合之间的交集。它计算self的{​​{1}}和 union 之间的交集。

结果不同,因为others调用了x & y & z,而Extend.intersect(Extend.intersect(x,y), z)调用了x.intersect(y,z)并且给出了Extend.intersect(x, *[y,z]) 实际所做的事情,那些碰巧是不同的操作。