roboti

Time limit: 0.1s Memory limit: 8MB Input: roboti.in Output: roboti.out

O firmă de construcţii imobiliare a achiziţionat recent un teren dreptunghiular de dimensiuni N×MN×M. Terenul este împărțit în parcele de dimensiune 1x1. Pe unele dintre cele N×MN×M 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ă LL. Suprafața defrișată de fiecare robot la un moment dat este chiar aria de acoperire a robotului, L×LL×L. Fiecare robot pătrunde prin colțul stânga sus de coordonate (1,1)(1, 1), se poate deplasa doar în dreapta și în jos și poate părăsi suprafața numai prin colțul dreapta jos, de coordonate (N,M)(N, M).

Cerinţă

Cunoscând dimensiunile NN, MM ale terenului și coordonatele parcelelor în care sunt plantați copaci se cere:

  1. Numărul minim de roboți necesari defrișării întregului teren.
  2. Să se răspundă la QQ interogări de forma kk, unde kk 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 kk roboți.

Date de intrare

Fişierul de intrare roboti.in conţine:

  • Pe prima linie un număr natural pp reprezentând varianta cerinței de rezolvare. Pentru toate testele de intrare, numărul pp poate avea doar valoarea 1 sau valoarea 2.
  • Pe a doua linie se află 3 numere naturale NN, MM, TT 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 TT linii conțin fiecare câte două numere naturale x,yx, y 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 QQ, iar ultima linie QQ numere naturale k1,k2,...,kQk_1, k_2, ..., k_Q separate prin câte un spațiu, reprezentând numărul maxim de roboți ce pot fi utilizați în fiecare dintre cele QQ interogări.

Date de ieșire

  • Dacă valoarea lui pp 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 n1n_1, reprezentând numărul minim de roboți utilizați.
  • Dacă valoarea lui pp este 2, se va rezolva numai cerința 2. În acest caz, în fişierul de ieşire roboti.out se vor scrie QQ linii. Fiecare linie i va conţine câte un număr natural nin_i, reprezentând latura minimă a unui robot astfel încât pentru defrișare să fie utilizați cel mult kik_i roboți.

Restricții și precizări

  • 2N,M,L1502 \leq N, M, L \leq 150;
  • 1Q1501 \leq Q \leq 150;
  • 1ki150,1iQ1 \leq k_i \leq 150, 1 \leq i \leq Q;
  • 1T1 0001 \leq T \leq 1 \ 000;
  • 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

p=1p = 1. 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

p=2p = 2. 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.

Log in or sign up to be able to send submissions!