Напишите функцию, которая будет принимать два списка (lst1
и lst2
), а также целое число n
, и проверять, равен ли второй список первому, циклически смещенному на n
позиций.
Примечания
- Списки будут одинаковой длины.
n
может быть отрицательным числом.
Примеры
circular_shift([1, 2, 3, 4], [3, 4, 1, 2], 2) ➞ True circular_shift([1, 1], [1, 1], 6) ➞ True circular_shift([0, 1, 2, 3, 4, 5], [3, 4, 5, 2, 1, 0], 3) ➞ False
Варианты решения
def circular_shift(lst1, lst2, n): return lst1 == lst2[n:] + lst2[:n]
def circular_shift(lst1, lst2, n): l = [lst1[(i - n) % len(lst1)]for i, x in enumerate(lst1)] return l == lst2