Коридор

Есть план этажа здания. На этом этаже 4 комнаты (1, 2, 3, 4), все выходят в общий коридор. Комнаты не сообщаются между собой: чтобы перейти из одной комнаты в любую другую, нужно пройти через коридор.

План этажа: комнаты 1 и 2 сверху, комнаты 3 и 4 снизу, между ними коридор. Все комнаты имеют выход только в коридор.

Создайте функцию, которая будет проверять, возможен ли переданный ей путь по комнатам. Коридор будет обозначаться буквой «H» (Hall).

Примеры

 possible_path([1, "H", 2, "H", 3, "H", 4]) ➞ True
 possible_path(["H", 3, "H"]) ➞ True
 possible_path([1, 2, "H", 3]) ➞ False

Примечания

  • Путь может начинаться или кончаться в коридоре.
  • В качестве инпута будут передаваться только цифры 1-4 и/или буква «H».
  • Комнаты не будут повторяться.

Варианты решений

def possible_path(lst):
    return len(set(type(i) for i in lst[::2])) == 1
def possible_path(lst):
  
    valid_pair = lambda n1, n2: True if n1 == 'H' and n2 in range(1, 5) or n2 == 'H' and n1 in range(1, 5) else False
    answer = True
  
    for n in range(len(lst) - 1):
        ci = lst[n]
        ni = lst[n+1]
    
        answer = valid_pair(ci, ni)
    
        if answer == False:
            break
  
    return answer
def possible_path(lst):
    if len(lst) == 1:
        return True
    return all(idx % 2 for idx, i in enumerate(lst) if i == "H") or \
        all(not idx % 2 for idx, i in enumerate(lst) if i == "H") and not lst.count("H") % 2