Информатика, вопрос задал 675678yfcyfc , 1 год назад

Айбар и Есма устали играть игру FAFI 2320, и придумали свою игру. Игра происходит на дереве размером n. Изначально, Есма на вершине u ставит свою фишку, а Айбар ставит свою фишку на вершине v. Игра происходит следующим образом:

Если фишки Айбара и Есмы стоят на одной вершине, игра заканчивается. В противном случае, Есма двигает свою фишку, по своему выбору, которая смежна с его текущей вершиной.
Если фишки Айбара и Есмы стоят на одной вершине, игра заканчивается. В противном случае, Айбар двигает свою фишку, по своему выбору, которая смежна с его текущей вершиной.
Возвращаемся к шагу 1.
Есма хочет как можно дольше оставаться наедине с Айбаром, из-за этого его цель сделать количество ходов как можно больше. А у Айбара есть срочные дела, он должен решать задачи из codeforces и его цель сделать игру как можно короче. Найдите количество ходов, которые Айбар совершит до окончания игры, если и Есма, и Айбар знают позицию и стратегию друг друга. Игроки играют оптимально.
Входные данные
В первой строке даны n, u, v. (1≤u,v≤n≤105,u≠v)
Далее в n−1 строках даны пары чисел (ai,bi)(1≤ai,bi≤n,ai≠bi) - ребра дерева.

Выходные данные
Выведите количество ходов, которые Айбар совершит до окончания игры.
написать на пайтон, js

Ответы на вопрос

Ответил Pashtet2023
0

Ответ: ниже

Объяснение:Для решения этой задачи мы можем использовать поиск в глубину (Depth-First Search, DFS) для определения расстояния между вершинами u и v. Мы будем использовать два обхода DFS: один из u, чтобы найти путь до v, а другой из v, чтобы найти путь до u.

Во время первого обхода DFS мы будем сохранять расстояние от каждой посещенной вершины до u в массиве dist1[], а во время второго обхода DFS будем сохранять расстояние от каждой посещенной вершины до v в массиве dist2[]. Затем мы найдем наименьшее расстояние между u и v, а затем вычтем 1 (так как последний ход Айбара не приведет к перемещению).

реализация данного алгоритма на языке Python:

python

from collections import defaultdict

# Реализация класса графа

class Graph:

   def __init__(self):

       self.graph = defaultdict(list)

   # Добавление ребра в граф

   def add_edge(self, u, v):

       self.graph[u].append(v)

       self.graph[v].append(u)

   # Обход в глубину с подсчетом расстояния

   def dfs(self, start, dist):

       visited = [False] * (len(self.graph) + 1)

       stack = []

       stack.append(start)

       dist[start] = 0

       visited[start] = True

       while stack:

           s = stack.pop()

           for i in self.graph[s]:

               if not visited[i]:

                   visited[i] = True

                   stack.append(i)

                   dist[i] = dist[s] + 1

   # Вычисление расстояния между вершинами u и v

   def find_distance(self, u, v):

       dist1 = [-1] * (len(self.graph) + 1)

       dist2 = [-1] * (len(self.graph) + 1)

       # Обход в глубину из u

       self.dfs(u, dist1)

       # Обход в глубину из v

       self.dfs(v, dist2)

       # Находим наименьшее расстояние между u и v

       min_dist = float('inf')

       for i in range(1, len(self.graph) + 1):

           if dist1[i] != -1 and dist2[i] != -1:

               curr_dist = dist1[i] + dist2[i]

               min_dist = min(min_dist, curr_dist)

       # Вычитаем 1, так как последний ход Айбара не приведет к перемещению

       return min_dist - 1

# Чтение входных данных

n, u, v = map(int, input().split())

graph = Graph()

# Добавление ребер в граф

for i in range(n - 1):

   a, b = map(int, input().split())

   graph.add_edge(a, b)

# Вычисление расстояния между u и v

distance = graph.find_distance(u, v)

# Вывод результата

print(distance)

Пример входных данных:

6 1 4

1 2

2 3

3 4

4 5

4 6

Пример выходных данных:

2

Новые вопросы