Gara de Nord este cea mai vestită gară din lume. Japonezii, invidioşi pe sistemul performant de întârziere al trenurilor din Gara de Nord, s-au hotărât să analizeze motivul realizării unei astfel de performanțe.
În Gara de Nord (considerată stația 0
) există N
trenuri. Pentru fiecare tren i
știm că va pleca din Gara noastră protagonistă (stația 0
) și o să meargă până la stația . Staţiile x
şi x+1
sunt legate în mod direct pentru orice x
, astfel că trenul i
va opri în toate stațiile din intervalul . De asemenea, știm că trenul i
are o capacitate egală cu numărul maxim de oameni pe care îl poate transporta. Această capacitate este notată cu .
Avem M
pasageri dornici să folosească magnificul traseu. Pentru fiecare pasager i
știm intervalul de statii pe care vrea să îl parcurgă. Mai exact, acesta vrea să se urce într-un tren în stația și să coboare în stația .
Cerință
Din cauza capacității limitate a trenurilor, este posibil ca nu toți pasagerii sa poată obțină un loc și să ajungă în destinația dorită. Să se determine numărul maxim de pasageri care pot ajunge din stația de plecare în stația de sosire, precum și o configurație în care aceștia se pot urca în trenuri.
Date de intrare
Pe prima linie a fișierului trenuri.in
se află 2
numere naturale N
și M
, separate printr-un spațiu, cu semnificația din enunț. Următoarele N
linii vor descrie cele N
trenuri. Pe linia i + 1
se vor afla două valori întregi separate prin câte un spațiu: și care descriu trenul cu numărul i
. Urmatoarele M
linii vor descrie itinerariile celor M
pasageri. Astfel, pe linia N + i + 1
se vor afla două valori întregi și , separate printr-un spațiu reprezentând stațiile între care dorește să circule pasagerul cu numărul i
.
Date de ieșire
Pe prima linie a fișierului trenuri.out
se va afișa un număr natural P
, reprezentând numărul maxim de pasageri care pot să își realizeze traseul propus. Pe următoarele M
linii se vor afișa M
numere naturale. Astfel, pe linia i + 1
se va afișa trenul în care va urca pasagerul i
. Dacă pasagerul i
nu poate să se urce în niciun tren, se va afișa valoarea 0
.
Restricții
1 ≤ N, M ≤ 100 000
- pentru orice
i, 1 ≤ i ≤ N
. - pentru orice
i, 1 ≤ i ≤ M
. - Un pasager nu poate să coboare dintr-un tren și să ia alt tren. Pasagerul
i
poate să urce doar în stația și să coboare doar la stația . - Pot exista mai multe soluții pentru repartizarea pasagerilor în trenuri. Orice soluție cu număr maxim de pasageri posibil va obține punctaj maxim.
- Pentru afișarea numărului corect de pasageri se va acorda
30%
din punctajul pe un test. - Pentru
20%
din testeN = 1
. - Pentru
60%
din testeN, M ≤ 2000
. - Trenurile sunt indexate de la
1
laN
.
Exemple
trenuri.in
2 3
10 1
15 1
2 8
7 10
8 13
trenuri.out
3
2
1
2
Explicații
Primul și ultimul pasager vor urca în trenul 2
, iar pasagerul 2
în trenul 1
.
Dacă pasagerul 1
s-ar fi urcat în trenul 1
, ar fi trebuit sa alegem care dintre pasagerul 2
și 3
să se urce în trenul 2
deoarece cele 2
itinerarii se intersectează, iar cei doi pasageri nu ar avea loc în același tren.
trenuri.in
1 3
10 2
1 5
3 7
4 9
trenuri.out
2
1
0
1
Explicații
Orice combinație în care selectăm 2
din cei 3
pasageri se consideră validă.