Маленькая Ева только учится играть в шахматы. Сегодня она узнала, как слон ходит по шахматной доске. Теперь она хочет понять, куда слон может добраться не более чем за 100 ходов. Помогите Еве понять, может ли слон добраться от одной клетки до другой клетки шахматной доски.
Шахматный слон за один ход перемещается по диагонали на любое количество клеток. Шахматная доска имеет размеры 8 × 8.
Входные данные
Программа получает на вход 4 числа, записанных в отдельных строках. Первые два числа — номер строки и номер столбца исходной клетки, следующие два числа — номер строки и номер столбца конечной клетки (каждое число принимает значения от 1 до 8). Гарантируется, что исходная и конечная клетки не совпадают.
Выходные данные
В первой строке выведите Yes или No — ответ на вопрос задачи. Если в первой строке вы вывели Yes, то во второй строке выведите число n — количество ходов слона (число не превосходящее 100). В следующих n строках выведите последовательно клетки (номер строки и номер столбца клетки через пробел), в которые нужно перемещать слона. Последняя выведенная клетка должна совпадать с заданной конечной клеткой.
Вам не нужно минимизировать число ходов слона, но оно не должно превосходить 100.
Система оценки
В этой задаче 20 тестов, помимо тестов из условия. Каждый тест оценивается в 5 баллов независимо от остальных.
Примеры
Ввод
Вывод
1
1
1
7
Yes
2
4 4
1 7
3
2
3
8
Yes
3
5 4
2 7
3 8
1
1
1
2
No
Ответы
Ответ:
def def_color(x, y):
# 1 black, 2 white
return 1 if (x + y) % 2 == 0 else 0
def get_direction(cur_coords, target_coords):
x_dir = 0
y_dir = 0
x_s, y_s = cur_coords
x_f, y_f = target_coords
# right = 1, left = 0
if x_f - x_s >= 0:
x_dir = 1
else:
x_dir = 0
# up = 1, down = 0
if y_f - y_s >= 0:
y_dir = 1
else:
y_dir = 0
return (x_dir, y_dir)
def make_step(coords, direction):
x, y = coords
if sum(direction) == 2:
return (x+1, y+1) # right up
elif sum(direction) == 0:
return (x-1, y-1) # left down
else:
if direction[0] == 0: # left
if direction[1] == 1: # up
return (x-1, y+1)
else: # right down
return (x+1, y-1)
def main():
start_x = int(input())
start_y = int(input())
target_x = int(input())
target_y = int(input())
finish_coords = (target_x, target_y)
step_hist = [[start_x, start_y]]
if def_color(start_x, start_y) != def_color(target_x, target_y):
print("No")
return
while True:
direction = get_direction(step_hist[-1], finish_coords)
step_hist.append(make_step(step_hist[-1], direction))
if step_hist[-1] == finish_coords:
break
print("Yes")
step_hist.pop(0)
print(len(step_hist))
for x, y in step_hist:
print(x, y)
return
main()
Объяснение:
Вроде так,спасибо gravitationgg за ответ