Gigel are în fața sa pe o foaie de matematică un desen obținut prin trasarea mai multor linii orizontale și verticale de lungime de-a lungul modelului foii de matematică.
Gigel a învăţat de la colegii mai mari un joc, care se joacă în doi: delimitează pe foaia de matematică o zonă dreptunghiulară, apoi, pe rând, trag cu creionul câte o linie pe o latură a unui pătrăţel. Cel care reuşeşte să formeze cele mai multe pătrăţele câştigă. Ochii lui Gigel sunt obişnuiţi să vadă imediat o problemă de matematică, chiar dacă se joacă.
Privind desenul de pe foaie el se întreabă: “Oare câte pătrate s-au format din liniile trasate?”
În desenul alăturat se vede foaia formată din linii şi coloane, precum şi liniile trasate până la un moment dat. Se pot distinge trei pătrate de latură , două pătrate de latură şi un pătrat de latură .
În problema noastră vom codifica fiecare pătrat de latură de pe foaie cu un număr natural cuprins între şi obținut prin însumarea codificării fiecărei laturi astfel:
- – dacă latura de sus este trasată
- – dacă latura din dreapta este trasată
- – dacă latura de jos este trasată
- – dacă latura din stânga este trasată
Apoi se face suma codificărilor laturilor pentru a afla codificarea fiecărui pătrățel. În acest fel desenul alăturat poate fi codificat printr-un tablou bidimensional de dimensiuni cu valorile:
9 7 15 13 7
14 15 11 15 11
1 3 12 7 14
Cerință
Fiind date dimensiunile şi ale foii de matematică, precum şi tabloul bidimensional de dimensiune care conține codificarea foii, să se determine:
- numărul total de pătrate existente pe foaia de matematică în desenul realizat conform codificării
- distribuția numărului de pătrate în ordinea strict crescătoare a lungimii laturilor
- unde poate fi trasată încă o linie astfel încât numărul total de pătrate să crească și să devină maxim posibil
Date de intrare
Fişierul de intrare patratele.in
conţine pe prima linie trei numere naturale , separate prin câte un spaţiu, indicând dimensiunile foii de matematică , respectiv cerinţa care trebuie rezolvată ( sau ). Fiecare dintre următoarele linii conţine câte numere naturale, fiecare dintre acestea reprezentând codificarea foii de matematică.
Date de ieșire
Fișierul de ieșire patratele.out
va conține următoarele în funcție de cerința cerută:
- Dacă , pe prima linie numărul total de pătrate determinat;
- Dacă , pe fiecare linie vor fi afișate câte două numere naturale nenule și , separate printr-un spaţiu, indicând lungimea laturii pătratelor (), respectiv numărul de pătrate cu latura de lungimea respectivă (), în ordinea strict crescătoare a valorilor lui ;
- Dacă , prima linie va conține numărul maxim de pătrate, iar linia a doua va conține două valori naturale și un cuvânt separate printr-un spațiu, unde reprezintă coordonatele pătratului de latură unde se trasează linia suplimentară, iar
SUS
DREAPTA
JOS
STANGA
NU
(se va afișaNU
în cazul în care nu se poate trasa nicio linie — în acest caz cele trei valori numerice afișate vor fi de asemenea ).
Restricții și precizări
- Numerotarea liniilor și coloanelor foii de matematică începe de la .
- Dacă la cerința se obțin mai multe poziții de trasare a liniei, se va afișa soluția cu indicele liniei minim, iar în caz de egalitate după linii, se va afișa soluția cu indicele coloanei minim. În cazul în care există mai multe posibilități de trasare a unei linii în același pătrat, pozițiile vor fi luate în ordinea
SUS
,DREAPTA
,JOS
,STANGA
. - Pentru de puncte, .
- Pentru de puncte, .
- Pentru puncte, și .
- Pentru de puncte, .
Exemplul 1
patratele.in
3 5 1
9 7 15 13 7
14 15 11 15 11
1 3 12 7 14
patratele.out
6
Explicație
Se rezolvă cerința . În total au fost găsite pătrate
Exemplul 2
patratele.in
3 5 2
9 7 15 13 7
14 15 11 15 11
1 3 12 7 14
patratele.out
1 3
2 2
3 1
Explicație
Se rezolvă cerința .
pătrate de latură
pătrate de latură
pătrat de latură
Exemplul 3
patratele.in
3 5 3
9 7 15 13 7
14 15 11 15 11
1 3 12 7 14
patratele.out
9
2 5 JOS
Explicație
Se rezolvă cerința . Dacă se trasează încă o linie la pătratul din linia coloana jos, se mai obțin încă pătrate.
Exemplul 4
patratele.in
3 3 3
9 1 3
8 0 2
12 0 0
patratele.out
0
0 0 NU
Explicație
Se rezolvă cerința . Nu se poate adăuga niciun pătrat nou prin trasarea unei singure linii.