Python: determining whether any item in sequence is equal to any other

冷暖自知 提交于 2019-12-18 21:51:12

问题


I'd like to compare multiple objects and return True only if all objects are not equal among themselves. I tried using the code below, but it doesn't work. If obj1 and obj3 are equal and obj2 and obj3 are not equal, the result is True.

obj1 != obj2 != obj3

I have more than 3 objects to compare. Using the code below is out of question:

all([obj1 != obj2, obj1 != obj3, obj2 != obj3])

回答1:


@Michael Hoffman's answer is good if the objects are all hashable. If not, you can use itertools.combinations:

>>> all(a != b for a, b in itertools.combinations(['a', 'b', 'c', 'd', 'a'], 2))
False
>>> all(a != b for a, b in itertools.combinations(['a', 'b', 'c', 'd'], 2))
True



回答2:


If the objects are all hashable, then you can see whether a frozenset of the sequence of objects has the same length as the sequence itself:

def all_different(objs):
    return len(frozenset(objs)) == len(objs)

Example:

>>> all_different([3, 4, 5])
True
>>> all_different([3, 4, 5, 3])
False



回答3:


If the objects are unhashable but orderable (for example, lists) then you can transform the itertools solution from O(n^2) to O(n log n) by sorting:

def all_different(*objs):
    s = sorted(objs)
    return all(x != y for x, y in zip(s[:-1], s[1:]))

Here's a full implementation:

def all_different(*objs):
    try:
        return len(frozenset(objs)) == len(objs)
    except TypeError:
        try:
            s = sorted(objs)
            return all(x != y for x, y in zip(s[:-1], s[1:]))
        except TypeError:
            return all(x != y for x, y in itertools.combinations(objs, 2))



回答4:


from itertools import combinations
all(x != y for x, y in combinations(objs, 2))



回答5:


You can check that all of the items in a list are unique by converting it to a set.

my_obs = [obj1, obj2, obj3]
all_not_equal = len(set(my_obs)) == len(my_obs)


来源:https://stackoverflow.com/questions/11728662/python-determining-whether-any-item-in-sequence-is-equal-to-any-other

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!