我认为set
是wot您正在查找。
您可以添加和减去集合,找到它们的交集 因此,所有你需要找到动物园哪一组动物具有不属于动物组的其他动物园的项目。如果你将在动物园中减去动物中的所有其他动物,你就会得到独特的动物。
zoos = ['mouse,dog', 'dog,tiger,mouse', 'mouse,cat']
for zoo in zoos:
zoo_animal = set(zoo.split(','))
other_zoo_animals = set(animal for z in zoos if z != zoo for animal in z.split(','))
unique_animals = zoo_animal - other_zoo_animals
if unique_animals:
print "%s: %s" % (zoo, unique_animals)
或者你可以找出每个动物的居住地:
zoos = ['mouse,dog', 'dog,tiger,mouse', 'mouse,cat']
animals = {}
for i, zoo in enumerate(zoos):
zoo_animal = set(zoo.split(','))
for animal in zoo_animals:
animals.setdefault(animal, []).append(i)
# Now You can iterate over all animals and find ones which are only present in one zoo
for animal, zoo_list in animals.iteritems():
if len(zoo_list) == 1:
print("% lives in %s only" % (animal, zoo_list[0]))
您可以添加数据结构的一些例子吗? –
如果您显示代码和数据,而不是仅仅描述它,它会更好。 – TryPyPy