|
||||||||||||||||||
ultima problemă
grupă: mică
sursă: OMI 2016 ultimul articol
autor: Prof. Radu Vişinescu
ultimul software
autor: Prof. Emanuela Cerchez
|
Danut a crescut intr-o metropola numita Bucuresti. Cand a ajuns in clasa a 7-a a realizat ca Bucuresti-ul este un oras foarte ciudat: are 2N intersectii, fiecare intersectie fiind numerotata cu un numar unic intre 0 si 2N-1 (inclusiv). Mai mult, se pare ca fostii primari au fost informaticieni la viata lor, pentru ca au construit strazi numai intre doua intersectii pentru care, scrise in baza 2, numerele asociate difera doar printr-o singura cifra. De exemplu intre intersectiile 2 (10) si 3 (11), sau 5 (0101) si 13 (1101) exista strada, dar intre intersectiile 4 (0100) si 9 (1001) sau 11 (01011) si 17 (10001) nu exista strada ce le conecteaza direct. In plus, strazile au fost si ele numerotate. Astfel, daca intre intersectiile X si Y exista strada atunci ea va fi numerotata cu log2|X-Y|. Atentie! fiecare strada va fi mereu numerotata cu un numar intreg, si pot exista mai multe strazi numerotate la fel. De exemplu strada ce conecteaza intersectiile 5 si 13 va fi numerotata cu 3 (log2|5-13| = log28 = 3). Pentru ca nu poate sa adoarma Danut se gandeste in fiecare seara la cate doua intersectii si vrea sa stie toate drumurile disjuncte ce le interconecteaza. Ajutati-l, va rog, sa scape de insomnii. Cerinta Dandu-se M perechi de intersectii, determinati pentru fiecare pereche toate drumurile disjuncte intre cele doua intersectii. Date de intrare Fisierul de intrare metro.in va contine:
Date de iesire Fisierul de iesire metro.out va contine pentru fiecare pereche Ai, Bi din fisierul de intrare un numar Ki reprezentand numarul de drumuri disjuncte dintre intersectiile Ai, Bi, iar pe urmatoarele Ki linii se va afisa cate un drum de la Ai la Bi. Pentru fiecare drum se vor afisa numerele strazilor parcurse plecand din intersectia Ai si terminand in intersectia Bi. Numerele strazilor ce apartin aceluiasi drum vor fi despartite prin cate un spatiu. Restrictii si precizari
Exemplu
Alexandru Mosoi propunător: Prof. Emanuela Cerchez emanuela.cerchez@gmail.com Articole recomandate
Probleme recomandate
|
|||||||||||||||||
surse trimise | ajutor |