Антисписки (задача на сравнение списков в Python)

Напишите функцию, принимающую в виде аргументов два списка и определяющую, являются ли они противоположными друг другу. Функция должна возвращать 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

python logo

Свежие вакансии по Python

Для тех, кто хочет найти работу Junior Python Developer

×