#5005
Se dau 𝑁 procese care trebuie rulate pe un calculator. Există 𝑀 variabile care pot fi accesate de către aceste procese, numerotate de la 1 la 𝑀. Fiecare proces 𝑖 (unde 1 ≤ 𝑖 ≤ 𝑁) accesează un interval continuu de variabile [𝑙[𝑖], 𝑟[𝑖]], iar timpul necesar de execuție al procesului 𝑖 este 𝑡[𝑖].
Cât timp un proces rulează, acesta își salvează pe stiva de execuție toate variabilele necesare, iar la finalizarea lui le elimină de pe stivă. Două procese pot rula în paralel dacă și numai dacă nu au nicio variabilă în comun.
Sistemul de operare va planifica procesele astfel încât timpul total necesar executării tuturor să fie minim. O astfel
de planificare, care atinge timpul minim posibil, poartă numele de scenariu optim de execuție.
O variabilă este considerată critică dacă există cel puțin un scenariu optim de execuție în care aceasta petrece cel mai mult timp pe stivă dintre toate variabilele (într-un scenariu pot exista mai multe variabile critice simultan).
Dat fiind un număr 𝐶 ∈ {1, 2, 3}, reprezentând tipul cerinței:
Cerința 1. Să se determine timpul minim necesar pentru a rula toate cele 𝑁 procese date.
Cerința 2. Pentru fiecare proces 𝑖 (de la 1 la 𝑁), presupunem că îl eliminăm din sistem. Fie 𝑇[𝑖] timpul minim necesar pentru a rula restul de 𝑁 − 1 procese. Să se calculeze și să se afișeze suma tuturor valorilor 𝑇[𝑖], pentru 𝑖 de la 1 la 𝑁.
Cerința 3. Pentru fiecare proces 𝑖 (de la 1 la 𝑁), presupunem că îl eliminăm din sistem. Fie 𝑉[𝑖] numărul de variabile critice în contextul celorlalte 𝑁 − 1 procese, conform definiției anterioare. Să se calculeze și să se afișeze suma tuturor valorilor 𝑉[𝑖], pentru 𝑖 de la 1 la 𝑁.
| Problema | Calculator1 | Operații I/O |
calculator1.in/calculator1.out
|
|---|---|---|---|
| Limita timp | 1.7 secunde | Limita memorie |
Total: 512 MB
/
Stivă 64 MB
|
| Id soluție | #64275676 | Utilizator | |
| Fișier | calculator1.cpp | Dimensiune | 5.54 KB |
| Data încărcării | 27 Aprilie 2026, 16:08 | Scor/rezultat | 83 puncte |
calculator1.cpp: In function ‘int main()’: calculator1.cpp:75:11: warning: ignoring return value of ‘int fscanf(FILE*, const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 75 | fscanf(fin, "%d %d %d %d %d %lld %lld %lld", | ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 76 | &cerinta, &N, &M, &K, &MAXT, &a, &b, &c); | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ calculator1.cpp:94:15: warning: ignoring return value of ‘int fscanf(FILE*, const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 94 | fscanf(fin, "%lld %lld %lld", | ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~ 95 | &gen.seedL[i], &gen.seedLen[i], &gen.seedT[i]); | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 1 | 0.003 secunde | OK. | 3 | 3 | ||
| 2 | 0.001 secunde | OK. | 3 | 3 | ||
| 3 | 0.002 secunde | OK. | 3 | 3 | ||
| 4 | 0.038 secunde | OK. | 3 | 3 | ||
| 5 | 0.023 secunde | OK. | 3 | 3 | ||
| 6 | 0.023 secunde | OK. | 3 | 3 | ||
| 7 | 0.001 secunde | OK. | 3 | 3 | ||
| 8 | 0.001 secunde | OK. | 3 | 3 | ||
| 9 | 0.002 secunde | OK. | 3 | 3 | ||
| 10 | 0.003 secunde | OK. | 3 | 3 | ||
| 11 | 0.003 secunde | OK. | 3 | 3 | ||
| 12 | 0.003 secunde | OK. | 3 | 3 | ||
| 13 | 0.03 secunde | OK. | 3 | 3 | ||
| 14 | 0.04 secunde | OK. | 3 | 3 | ||
| 15 | 0.027 secunde | OK. | 3 | 3 | ||
| 16 | 0.627 secunde | OK. | 3 | 3 | ||
| 17 | 0.612 secunde | OK. | 3 | 3 | ||
| 18 | 0.629 secunde | OK. | 3 | 3 | ||
| 19 | 0.645 secunde | OK. | 3 | 3 | ||
| 20 | Depășit | Limita de timp depășită | 3 | 0 | ||
| 21 | Depășit | Limita de timp depășită | 2 | 0 | ||
| 22 | Depășit | Limita de timp depășită | 2 | 0 | ||
| 23 | Depășit | Limita de timp depășită | 2 | 0 | ||
| 24 | 0.001 secunde | OK. | 2 | 2 | ||
| 25 | 0.001 secunde | OK. | 2 | 2 | ||
| 26 | 0.001 secunde | OK. | 2 | 2 | ||
| 27 | 0.002 secunde | OK. | 2 | 2 | ||
| 28 | 0.002 secunde | OK. | 2 | 2 | ||
| 29 | 0.001 secunde | OK. | 2 | 2 | ||
| 30 | 0.034 secunde | OK. | 2 | 2 | ||
| 31 | 0.029 secunde | OK. | 2 | 2 | ||
| 32 | 0.029 secunde | OK. | 2 | 2 | ||
| 33 | 0.661 secunde | OK. | 2 | 2 | ||
| 34 | 0.696 secunde | OK. | 2 | 2 | ||
| 35 | 0.699 secunde | OK. | 2 | 2 | ||
| 36 | 0.649 secunde | OK. | 2 | 2 | ||
| 37 | Depășit | Limita de timp depășită | 2 | 0 | ||
| 38 | Depășit | Limita de timp depășită | 2 | 0 | ||
| 39 | Depășit | Limita de timp depășită | 2 | 0 | ||
| 40 | Depășit | Limita de timp depășită | 2 | 0 | ||
| Punctaj total | 83 | |||||
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Calculator1 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ă.