O firmă de construcţii imobiliare a achiziţionat recent un teren dreptunghiular de dimensiuni . Terenul este împărțit în parcele de dimensiune 1x1. Pe unele dintre cele parcele sunt plantați copaci. Firma dorește construirea unui grandios complex comercial și este necesară defrișarea întregului teren. În acest scop sunt utilizați roboți, fiecare robot având baza un pătrat de latură . Suprafața defrișată de fiecare robot la un moment dat este chiar aria de acoperire a robotului, . Fiecare robot pătrunde prin colțul stânga sus de coordonate , se poate deplasa doar în dreapta și în jos și poate părăsi suprafața numai prin colțul dreapta jos, de coordonate .
Cerinţă
Cunoscând dimensiunile , ale terenului și coordonatele parcelelor în care sunt plantați copaci se cere:
- Numărul minim de roboți necesari defrișării întregului teren.
- Să se răspundă la interogări de forma , unde este un număr natural. Pentru fiecare interogare de această formă va trebui determinată latura minimă a unui robot astfel încât să fie necesari pentru defrișare cel mult roboți.
Date de intrare
Fişierul de intrare roboti.in
conţine:
- Pe prima linie un număr natural reprezentând varianta cerinței de rezolvare. Pentru toate testele de intrare, numărul poate avea doar valoarea 1 sau valoarea 2.
- Pe a doua linie se află 3 numere naturale , , separate prin câte un spațiu reprezentând numărul liniilor, numărul coloanelor terenului dreptunghiular, respectiv numărul copacilor plantați.
- Următoarele linii conțin fiecare câte două numere naturale separate prin câte un spațiu, reprezentând linia, respectiv coloana parcelei în care este plantat un copac.
- În cazul cerinței 2, penultima linie va conține un număr natural , iar ultima linie numere naturale separate prin câte un spațiu, reprezentând numărul maxim de roboți ce pot fi utilizați în fiecare dintre cele interogări.
Date de ieșire
- Dacă valoarea lui este 1, se va rezolva numai cerința 1. În acest caz, în fişierul de ieşire
roboti.out
se va scrie un singur număr natural , reprezentând numărul minim de roboți utilizați. - Dacă valoarea lui este 2, se va rezolva numai cerința 2. În acest caz, în fişierul de ieşire
roboti.out
se vor scrie linii. Fiecare linie i va conţine câte un număr natural , reprezentând latura minimă a unui robot astfel încât pentru defrișare să fie utilizați cel mult roboți.
Restricții și precizări
- ;
- ;
- ;
- ;
- Latura robotului nu poate fi mai mare decât dimensiunile terenului;
- Pe tot parcursul deplasării, fiecare robot se va afla în interiorul suprafeţei terenului;
- În orice moment în interiorul suprafeţei terenului se va afla cel mult un robot.
Exemplul 1
roboti.in
1
6 8 8
4 1
5 3
3 5
2 6
5 5
4 7
3 8
6 8
4
roboti.out
1
Explicație
. Dacă roboții au latura 4, pentru defrișarea întregului teren este necesar un singur robot. Atenție! Pentru acest test se rezolvă doar cerința 1.
Exemplul 2
roboti.in
2
6 8 8
4 1
5 3
3 5
2 6
5 5
4 7
3 8
6 8
2
1 3
roboti.out
4
1
Explicație
. Prima valoare din fișierul de ieșire reprezintă latura minimă pe care o pot avea roboții astfel încât pentru defrișarea întregului teren să fie necesar un singur robot, conform primei interogări. A doua valoare din fișierul de ieșire reprezintă latura minimă pe care o pot avea roboții astfel încât pentru defrișarea întregului teren să fie necesari cel mult trei roboți, conform celei de-a doua interogări. Atenție! Pentru acest test se rezolvă doar cerința 2.