printРабочее место участника

printЗадачи

2271. Поездка на каникулах

Ограничения: время – 2s/4s, память – 256MiB Ввод: trains.in или стандартный ввод Вывод: trains.out или стандартный вывод copy
Послать решение Blockly Посылки Темы Где Обсудить (0)

Железная дорога Флатландии представляет собой прямую, вдоль которой расположены `n` станций. Будем называть участок железной дороги от некоторой станции до следующей перегоном.
Поезд следует от станции 1 до станции `n`, делая остановку на каждой станции. В поезде `k` мест, пронумерованных от 1 до `k`. На поезд продаются билеты, каждый билет характеризуется тремя числами: `s`, `t` и `a`. Такой билет позволяет проехать от станции `s` до станции `t` на месте `a`.
Иван планирует в один из дней летних каникул проехать на поезде от одной станции до другой. Он выяснил, что на поезд в этот день уже продано `m` билетов, и возможно уже нет мест, свободных на всех перегонах между интересующими его станциями. Билет от одной станции до другой на определенное место можно купить, только если это место свободно на всех перегонах между этими станциями.
Иван сообразил, что иногда все равно можно проехать от одной станции до другой, купив несколько билетов и пересаживаясь с одного места на другое на некоторых промежуточных станциях. Разумеется, пересаживаться с места на место неудобно, поэтому Иван хочет купить минимальное количество билетов, чтобы на каждом перегоне у него было свое место.
Иван еще не решил, от какой станции и до какой он поедет. Он записал `q` вариантов поездки, и для каждого из них хочет узнать, какое минимальное число билетов ему придется купить, если он выберет этот вариант.
Требуется написать программу, которая по заданному описанию уже проданных билетов и вариантов поездки Ивана определяет для каждого варианта, какое минимальное количество билетов необходимо купить, чтобы совершить такую поездку.
Формат входного файла
Первая строка входного файла содержит числа `n`, `m` и `k` (`2 ≤ n ≤ 200 000`, `0 ≤ m ≤ 200 000`, `1 ≤ k ≤ 200 000`) – количество станций, количество уже проданных билетов и количество мест в поезде. Последующие `m` строк содержат информацию о проданных билетах. Каждая строка содержит три числа: `s_i`, `t_i` и `a_i` – номер станции, от которой куплен билет, номер станции, до которой куплен билет, и номер места, на которое куплен билет (`1 ≤ s_i < t_i ≤ n`, `1 ≤ a_i ≤ k`). Гарантируется, что все билеты куплены таким образом, что ни на каком перегоне ни на какое место нет более одного билета.
Далее идет строка, которая содержит число `q` (`1 ≤ q ≤ 200 000`). Последующие `q` строк содержат описания вариантов поездки. Каждая строка содержат два числа: `f_j`, `d_j` – номер станции, от которой Иван хочет поехать в этом варианте, и номер станции, до которой он хочет поехать (`1 ≤ f_j < d_j ≤ n`).
Формат выходного файла
Выходной файл должен содержать `q` чисел: для каждого варианта поездки требуется вывести минимальное количество билетов, которое необходимо купить Ивану, чтобы совершить соответствующую поездку. Если поездку совершить невозможно, то для этого варианта требуется вывести `-1`.

Пример ввода

5 4 3
1 4 1
2 5 3
2 3 2
4 5 2
3
1 5
3 5
4 5

Пример вывода

-1
2
1
Пояснение к примеру
На перегоне от 2-й до 3-й станции все места заняты, поэтому проехать от 1-й до 5-й станции невозможно. От 3-й до 5-й станции можно проехать, используя два билета: от 3-й до 4-й станции на место 2 и от 4-й до 5-й на место 1. От 4-й до 5-й станции можно проехать, используя один билет на место 1.
Описание подзадач и системы оценивания
В этой задаче три подзадачи. Баллы за каждую подзадачу начисляются только в случае, если все тесты этой подзадачи успешно пройдены.
Внимание! Тест из примера не подходит под ограничения для подзадач 1 и 2, но решение принимается на проверку только в том случае, если оно выводит правильный ответ на тесте из примера. Решение должно выводить правильный ответ на тест даже, если оно рассчитано на решение только каких-либо из подзадач 1 и 2.
Подзадача 1 (33 балла)
`n ≤ 100`, `m ≤ 100`, `k ≤ 100`, `q\ =\ 1`
Подзадача 2 (30 баллов)
`n ≤ 200 000`, `m ≤ 200 000`, `k ≤ 200 000`, `q\ =\ 1`
Подзадача 3 (37 баллов)
`n ≤ 200 000`, `m ≤ 200 000`, `k ≤ 200 000`, `q\ ≤\ 200 000`
По запросу сообщаются баллы за каждую подзадачу.
Источник: региональный этап Всероссийской олимпиады по информатике 2015/2016, http://neerc.ifmo.ru/school/
loading