„Primăvara prin topirea zăpezii iau naștere râuri și lacuri numite Wadi, lacuri ce seacă vara.” (Wikipedia). Asta se întâmplă în Munții Atlas din nordul Africii. Noi avem de simulat aceasta în următorul mod:
Avem un șir de numere, care reprezintă înălțimile fiecărui loc în care poate ajunge apa. Fiecare element din șir reprezintă înălțimea în metri a unei zone cu lațimea de un metru. Zonele sunt lipite. Apa cade de pe poziția , de la o înălțime suficient de mare și va curge spre dreapta. Numim “unitate de apă” cantitatea de apă ce ocupă o zonă a unui pătrat X . De exemplu, dacă se va topi o cantitate de unități de apă, aceasta va cădea de pe zona spre dreapta și va ajunge să ocupe zonele hașurate. Se observă că dacă ajunge pe o anumită zonă apa curge spre dreapta până se lovește de un perete vertical. Noi lucrăm cu proiecția într-un plan a zonei imaginare, așa că vom considera toate elementele ca având grosime neglijabilă.
Cerință
Se dă configurația zonei și se cere, pentru mai multe cantități posibile de apă topită (exprimate în “unități de apă”), să se determine cea mai din dreapta poziție pe care ajunge apa și la ce înălțime ajunge pe acea poziție.
Date de intrare
În fișierul de intrare atlas.in
sunt mai multe teste. Pe prima linie a fișierului se găsește , numărul de teste. În continuare, sunt linii. Fiecare test este descris de linii astfel: Pe prima linie a testului se găsește , numărul de zone pe care le poate traversa apa după ce cade (acestea sunt numerotate de la la ). Se știe că apa cade de pe zona de înălțime infinită, iar la dreapta este zona , de înălțime de asemenea infinită. Pe linia a doua a testului sunt numere naturale, separate prin câte un spațiu, reprezentând, în ordine de la la înălțimile celor zone. Pe linia a treia a testului se găsește , numărul de întrebări. Pe linia a 4-a a testului sunt numere, separate prin câte un spațiu, ce reprezintă câte un număr de unități de apă care se topește.
Date de ieșire
Fișierul atlas.out
conține câte o linie pentru fiecare întrebare a fiecărui test, în ordinea apariției testelor și apoi în ordinea aparițiilor întrebărilor în fiecare test. Pe fiecare dintre acestea se află câte numere separate printr-un spațiu ce reprezintă, în ordine, răspunsul la fiecare întrebare. Primul număr este întreg și reprezintă poziția cea mai mare la care ajunge apa. Al doilea este un număr rațional și reprezintă înălțimea la care ajunge apa la poziția dată de primul număr. Acesta va fi afișat sub forma unei fracții ireductibile numarator/numitor
.
Restricții și precizări
- ;
- Înălțimile pilonilor ;
- Valorile din întrebări ;
- ;
- În scrierea numărului rațional nu se scrie spațiu nici înainte și nici după caracterul
/
Exemplu
atlas.in
2
5
0 3 1 4 5
3
4 9 6
3
2 3 1
2
1 2
atlas.out
3 2/1
4 17/4
3 10/3
1 3/1
3 2/1