Предмет: Информатика, автор: da2kAI

Маленькая Ева только учится играть в шахматы. Сегодня она узнала, как слон ходит по шахматной доске. Теперь она хочет понять, куда слон может добраться не более чем за 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

Ответы

Автор ответа: stalker28da
3

Ответ:

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 за ответ


alinamagomedova896: а как копировать?
stalker28da: Текст?Легко.Выделяешь его и нажимаешь ПКМ,CTRL+C и вставляешь
Похожие вопросы
Предмет: Математика, автор: Mariya20182018