blob: 68e84e82458f307c78550e25458a7be3932f5bf0 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
########################################################################
#
# File Name: Set.py
#
#
"""
WWW: http://4suite.org/ e-mail: support@4suite.org
Copyright (c) 2000-2001 Fourthought Inc, USA. All Rights Reserved.
See http://4suite.org/COPYRIGHT for license and copyright information
"""
def Not(original,other):
return filter(lambda x,other=other:x not in other,original)
def Union(left,right):
if len(left) < len(right):
loop = left
compare = right
else:
loop = right
compare = left
return compare + filter(lambda x,compare = compare:x not in compare,loop)
def Intersection(left,right):
if len(left) < len(right):
loop = left
compare = right
else:
loop = right
compare = left
return filter(lambda x,compare = compare:x in compare,loop)
def Unique(left):
return reduce(lambda rt,x:x in rt and rt or rt + [x],left,[])
|