#1044
Piramide
Fascinat de Egiptul Antic, Rareș vrea să construiască cât mai multe piramide din cartonașe pătratice identice. El are la dispoziție N
cartonașe numerotate de la 1
la N
, albe sau gri, așezate în ordinea strict crescătoare a numerelor.
1
și 2
așezate alăturat, peste care va așeza cartonașul 3
(vârful piramidei).4
, 5
și 6
așezate alăturat, deasupra cărora se vor așeza cartonașele 7
și 8
, alăturate, peste care se va așeza cartonașul 9
(vârful piramidei).4
cartonașe (cu numerele de la 10
la 13
), respectiv 5
cartonașe (cu numerele de la 20
la 24
), 6
cartonașe (cu numerele de la 35
la 40
) etc., cât timp va putea construi o piramidă completă. De exemplu, dacă Rareș are N=75
cartonașe atunci el va construi piramidele complete 1
, 2
, 3
, 4
și 5
din imaginile următoare. Din cele 75
de cartonașe el va folosi doar primele 55
de cartonașe, deoarece ultimele 20
cartonașe nu sunt suficiente pentru a construi piramida 6
, cu baza formată din 7
cartonașe.Scrieţi un program care să citească numerele naturale N
(reprezentând numărul de cartonașe), X
(reprezentând numărul unui cartonaș), K
(reprezentând numărul de cartonașe albe), numerele celor K
cartonașe albe c
1
, c
2
, …, c
K
și care să determine:
a) numărul P
al piramidei complete ce conține cartonașul numerotat cu X
;
b) numărul M
maxim de piramide complete construite de Rareș;
c) numărul C
de cartonașe nefolosite;
d) numărul A
al primei piramide complete care conține cele mai multe cartonașe albe.
OJI 2014, Clasa a V-a
Problema | Piramide | Operații I/O |
piramide.in /piramide.out
|
---|---|---|---|
Limita timp | 0.5 secunde | Limita memorie |
Total: 2 MB
/
Stivă 2 MB
|
Id soluție | #49262892 | Utilizator | |
Fișier | piramide.cpp | Dimensiune | 1.65 KB |
Data încărcării | 22 Februarie 2024, 19:05 | Scor / rezultat | 74 puncte |
piramide.cpp: In function 'int main()': piramide.cpp:13:27: warning: ignoring return value of 'int fscanf(FILE*, const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] fscanf (fin, "%d", &n); ^ piramide.cpp:14:27: warning: ignoring return value of 'int fscanf(FILE*, const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] fscanf (fin, "%d", &x); ^ piramide.cpp:15:27: warning: ignoring return value of 'int fscanf(FILE*, const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] fscanf (fin, "%d", &k); ^ piramide.cpp:71:30: warning: ignoring return value of 'int fscanf(FILE*, const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] fscanf(fin, "%d", &a); ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0 secunde | Cerinta a - gresit. Cerinta b - corect. Cerinta c - corect. Cerinta d - gresit. | 10 | 4 | ||
2 | 0 secunde | Cerinta a - gresit. Cerinta b - corect. Cerinta c - corect. Cerinta d - gresit. | 10 | 4 | ||
3 | 0 secunde | Cerinta a - gresit. Cerinta b - corect. Cerinta c - corect. Cerinta d - gresit. | 10 | 4 | ||
4 | 0 secunde | Cerinta a - gresit. Cerinta b - corect. Cerinta c - corect. Cerinta d - corect. | 10 | 8 | ||
5 | 0 secunde | Cerinta a - gresit. Cerinta b - corect. Cerinta c - corect. Cerinta d - corect. | 10 | 8 | ||
6 | 0 secunde | Cerinta a - gresit. Cerinta b - corect. Cerinta c - corect. Cerinta d - corect. | 10 | 8 | ||
7 | 0 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. Cerinta d - corect. | 10 | 10 | ||
8 | 0 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. Cerinta d - corect. | 10 | 10 | ||
9 | 0.02 secunde | Cerinta a - gresit. Cerinta b - corect. Cerinta c - corect. Cerinta d - corect. | 10 | 8 | ||
10 | 0 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. Cerinta d - corect. | 10 | 10 | ||
Punctaj total | 74 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Piramide 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ă.