Напишите функцию, принимающую в виде аргументов два списка и определяющую, являются ли они противоположными друг другу. Функция должна возвращать True или False.
Каждая пара списков будет состоять из одинаковых элементов (типа a и b). Список считается анти-списком, если все элементы в нем противоположны соответствующим элементам в первом списке.
Примеры
is_anti_list(["1", "0", "0", "1"], ["0", "1", "1", "0"]) ➞ True is_anti_list(["apples", "bananas", "bananas"], ["bananas", "apples", "apples"]) ➞ True is_anti_list([3.14, True, 3.14], [3.14, False, 3.14]) ➞ False
Примечание
Исходим из того, что в каждой паре списков будут элементы только двух видов.
Варианты решения
def is_anti_list(lst1, lst2): return all({a, b} == set(lst1) for a, b in zip(lst1, lst2))
def is_anti_list(lst1, lst2): seen = set() for i, j in zip(lst1, lst2): seen.update((i, j)) if i == j or len(seen) > 2: return False return True