#3037
Există azi mulți viruși care acționează în diferite moduri asupra informației stocate într-un calculator. Printre aceștia există și unii mai puțin periculoși, care se mulțumesc doar să simuleze o anumită alterare a informației. Să presupunem că dorim să scriem un astfel de virus care acționează doar asupra informației de tip text de pe ecranul calculatorului. În mod text, ecranul este constituit din n linii pe fiecare aflându-se câte m caractere. Caracterele sunt reținute în memoria calculatorului prin codul lor ASCII, reprezentat în binar pe 8 biți. Biții sunt numerotați de la 0 la 7 de la dreapta către stânga, cel din stânga fiind cel mai semnificativ bit. La fiecare secundă, virusul transformă simultan toate caracterele de pe ecran. Cunoscând configurația inițială a ecranului, scrieți un program care să rezolve următoarele două cerințe:
1. determină numărul de caractere inatacabile obținute în prima secundă (adică după prima transformare);
2. determină după câte secunde toate caracterele de pe ecran sunt inatacabile.
ONIGIM 2019, baraj
| Problema | virus | Operații I/O |
virus.in/virus.out
|
|---|---|---|---|
| Limita timp | 0.1 secunde | Limita memorie |
Total: 8 MB
/
Stivă 4 MB
|
| Id soluție | #57696315 | Utilizator | |
| Fișier | virus.cpp | Dimensiune | 2.72 KB |
| Data încărcării | 10 Aprilie 2025, 18:50 | Scor/rezultat | 100 puncte |
virus.cpp: In function 'int main()': virus.cpp:62:39: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if (cod[i][j].count()>maxim) maxim=cod[i][j].count(); ^ virus.cpp:69:41: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if ((cod[i][j].count()==maxim && maxim<=2) || cod[i][j].count()!=maxim && cycle(op2(cod[i][j])) || cod[i][j].count()==maxim && cycle(op1(cod[i][j]))) ++cnt; ^ virus.cpp:69:82: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if ((cod[i][j].count()==maxim && maxim<=2) || cod[i][j].count()!=maxim && cycle(op2(cod[i][j])) || cod[i][j].count()==maxim && cycle(op1(cod[i][j]))) ++cnt; ^ virus.cpp:69:88: warning: suggest parentheses around '&&' within '||' [-Wparentheses] if ((cod[i][j].count()==maxim && maxim<=2) || cod[i][j].count()!=maxim && cycle(op2(cod[i][j])) || cod[i][j].count()==maxim && cycle(op1(cod[i][j]))) ++cnt; ^ virus.cpp:69:135: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if ((cod[i][j].count()==maxim && maxim<=2) || cod[i][j].count()!=maxim && cycle(op2(cod[i][j])) || cod[i][j].count()==maxim && cycle(op1(cod[i][j]))) ++cnt; ^ virus.cpp:69:141: warning: suggest parentheses around '&&' within '||' [-Wparentheses] if ((cod[i][j].count()==maxim && maxim<=2) || cod[i][j].count()!=maxim && cycle(op2(cod[i][j])) || cod[i][j].count()==maxim && cycle(op1(cod[i][j]))) ++cnt; ^ virus.cpp:80:43: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if (cod[i][j].count()>maxim) maxim=cod[i][j].count(); ^ virus.cpp:89:44: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if (cod[i][j].count()==maxim) { ^ virus.cpp:92:49: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] else if (cod[i][j].count()!=maxim) { ^ virus.cpp:83:17: warning: unused variable 'cnt' [-Wunused-variable] int cnt=0; ^
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 0 | 0 secunde | OK. | 3 | 3 | ||
| 1 | 0 secunde | OK. | 7 | 7 | ||
| 2 | 0 secunde | OK. | 3 | 3 | ||
| 3 | 0 secunde | OK. | 7 | 7 | ||
| 4 | 0 secunde | OK. | 3 | 3 | ||
| 5 | 0 secunde | OK. | 7 | 7 | ||
| 6 | 0 secunde | OK. | 3 | 3 | ||
| 7 | 0 secunde | OK. | 7 | 7 | ||
| 8 | 0 secunde | OK. | 3 | 3 | ||
| 9 | 0 secunde | OK. | 7 | 7 | ||
| 10 | 0 secunde | OK. | 3 | 3 | ||
| 11 | 0 secunde | OK. | 7 | 7 | ||
| 12 | 0 secunde | OK. | 3 | 3 | ||
| 13 | 0 secunde | OK. | 7 | 7 | ||
| 14 | 0 secunde | OK. | 3 | 3 | ||
| 15 | 0 secunde | OK. | 7 | 7 | ||
| 16 | 0 secunde | OK. | 3 | 3 | ||
| 17 | 0 secunde | OK. | 7 | 7 | ||
| 18 | 0 secunde | OK. | 3 | 3 | ||
| 19 | 0 secunde | OK. | 7 | 7 | ||
| Punctaj total | 100 | |||||
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema virus 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ă.