#1026
Pseudobil
Suprafața plană a unei mese de pseudo-biliard este formată din n x n
celule pătratice cu lungimea laturii egală cu 1
(o unitate), lipite, dispuse pe n linii numerotate de la 1
la n
și n
coloane, numerotate de la 1
la n
. Pe masă se așează K
bile, fiecare bilă găsindu-se în centrul unei anumite celule a mesei. Un jucător dorește să plaseze pe suprafața mesei un cadru pătratic având lungimea diagonalei egală cu D
unități.
El trebuie să răspundă la m
întrebări de forma: x y
. Fiecare întrebare are semnificația: câte bile se găsesc în interiorul sau pe laturile cadrului ?
Cadrul se plasează astfel încât fiecare colț să fie poziționat în centrul unei celule, colțurile opuse să se găsească pe aceeași coloană, respectiv pe aceeași linie, iar colțul “de sus” să fie plasat în centrul celulei aflată pe linia x
și coloana y
.
Cunoscând lungimea n
a laturilor mesei, numărul m
de întrebări, numărul K
de bile așezate pe masă, pozițiile lor și lungimea D
a diagonalei cadrului pătratic, se cere:
1. Numărul de celule care se vor găsi în întregime în interiorul cadrului, dacă acesta se așează pe suprafața mesei, conform descrierii de mai sus.
2. Câte un răspuns pentru fiecare dintre cele m
întrebări.
OJI 2014, Clasa a IX-a
Problema | Pseudobil | Operații I/O |
pseudobil.in /pseudobil.out
|
---|---|---|---|
Limita timp | 1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 16 MB
|
Id soluție | #4290497 | Utilizator | |
Fișier | pseudobil.cpp | Dimensiune | 1.27 KB |
Data încărcării | 12 Februarie 2017, 14:19 | Scor / rezultat | 20 puncte |
pseudobil.cpp: In function 'int main()': pseudobil.cpp:7:39: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result] freopen ("pseudobil.in","r",stdin); ^ pseudobil.cpp:8:41: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result] freopen ("pseudobil.out","w",stdout); ^ pseudobil.cpp:9:21: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf ("%d", &t); ^ pseudobil.cpp:10:35: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf ("%d %d %d", &n, &k, &d); ^ pseudobil.cpp:13:32: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf ("%d %d", &x, &y); ^ pseudobil.cpp:57:25: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf ("%d", &m); ^ pseudobil.cpp:60:36: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf ("%d %d", &x, &y); ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0 secunde | OK. | 5 | 5 | ||
2 | 0.004 secunde | OK. | 5 | 5 | ||
3 | 0.016 secunde | OK. | 5 | 5 | ||
4 | 0.44 secunde | OK. | 5 | 5 | ||
5 | 0 secunde | Raspuns gresit. | 5 | 0 | ||
6 | 0 secunde | Raspuns gresit. | 5 | 0 | ||
7 | 0.008 secunde | Raspuns gresit. | 5 | 0 | ||
8 | 0.016 secunde | Raspuns gresit. | 5 | 0 | ||
9 | 0.016 secunde | Raspuns gresit. | 5 | 0 | ||
10 | 0.028 secunde | Raspuns gresit. | 5 | 0 | ||
11 | 0.06 secunde | Raspuns gresit. | 5 | 0 | ||
12 | 0.084 secunde | Raspuns gresit. | 5 | 0 | ||
13 | 0.08 secunde | Raspuns gresit. | 5 | 0 | ||
14 | 0.104 secunde | Raspuns gresit. | 5 | 0 | ||
15 | 0.16 secunde | Raspuns gresit. | 5 | 0 | ||
16 | 0.228 secunde | Raspuns gresit. | 5 | 0 | ||
17 | 0.744 secunde | Raspuns gresit. | 5 | 0 | ||
18 | 0.824 secunde | Raspuns gresit. | 5 | 0 | ||
19 | Depășit | Limita de timp depășită | 5 | 0 | ||
20 | Depășit | Limita de timp depășită | 5 | 0 | ||
Punctaj total | 20 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Pseudobil face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:
Suma punctajelor acordate pe testele utilizate pentru verificare este 100. Astfel, soluția ta poate obține cel mult 100 de puncte, caz în care se poate considera corectă.