Logo
(追記) (追記ここまで)

29529번 - Почтовая реформа 다국어

시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 1024 MB49221840.000%

문제

В Флатландии идет пора реформ. Недавно была проведена реформа дорог, так что теперь по дорогам страны из любого города можно добраться в любой другой, причем только одним способом. Также была проведена реформа волшебников, так что в каждом городе остался ровно один волшебник. Теперь же началась реформа почтовой системы.

Недавно образованное почтовое агентство <<Экс-Федя>> предлагает уникальную услугу --- коллективную посылку. Эта услуга позволяет отправлять посылки жителям всех городов на каком-либо пути по цене обычной посылки. Удивительно, но пользоваться такой услугой стали только волшебники Флатландии, которые стали в большом количестве отправлять друг другу магические кактусы. Агентство столкнулось с непредвиденной проблемой: как известно, все волшебники живут в башнях и мало того, что не строят в них лестницы, так еще время от времени меняют их высоту. Поэтому, чтобы доставить посылку волшебнику, который живет в башне высотой $h,ドル курьеру агентства требуется иметь с собой не менее $h$ метров веревки.

Вам поручено руководить отделом логистики --- по имеющимся данным о высотах башен и об их изменениях вам нужно определять минимальную длину веревки, которую нужно выдать курьеру, который доставляет посылки между городами $i$ и $j$.

입력

Первая строка входного файла содержит число $n$ --- количество городов в Флатландии (1ドル \le n \le 50000$). Во второй строке находится $n$ положительных чисел, не превосходящих 10ドル^5$ --- высоты башен в городах. В следующих $n-1$ строках содержится по два числа $u_i$ и $v_i$ --- описание $i$-й дороги, 1ドル \le u_i, v_i \le n, u_i \ne v_i$. В следующий строке содержится число $k$ --- количество запросов (1ドル \le k \le 100000$). В следующих $k$ строках содержатся описания запросов в следующем формате:

  • Уведомление от волшебника из города $i$ о том, что высота его башни стала равна $h,ドル имеет вид $!$ $i$ $h,ドル 1ドル \le i \le n,ドル 1ドル \le h \le 10^5$.
  • Запрос от курьера о выдаче веревки для доставки посылок во все города на пути от $i$ до $j$ включительно имеет вид $?$ $i$ $j,ドル 1ドル \le i, j \le n$.

출력

Для каждого запроса доставки посылок выведите минимальную длину веревки, которую необходимо выдать курьеру.

제한

예제 입력 1

3
1 2 3
1 3
2 3
5
? 1 2
! 1 5
? 2 3
! 3 2
? 1 2

예제 출력 1

3
3
5

예제 입력 2

1
100
5
! 1 1
? 1 1
! 1 1000
? 1 1
! 1 1

예제 출력 2

1
1000

힌트

출처

Olympiad > Russian Olympiad in Informatics > Internet Olympiads in Informatics > 2010-2011 Season > December 11, 2010 D번

(追記) (追記ここまで)

출처

대학교 대회

  • 사업자 등록 번호: 541-88-00682
  • 대표자명: 최백준
  • 주소: 서울시 서초구 서초대로74길 29 서초파라곤 412호
  • 전화번호: 02-521-0487 (이메일로 연락 주세요)
  • 이메일: contacts@startlink.io
  • 통신판매신고번호: 제 2017-서울서초-2193 호

AltStyle によって変換されたページ (->オリジナル) /