#4406
Fibosnek
Se consideră o matrice cu n
linii și m
coloane ce conține numere naturale nenule. Se definește o parcurgere snek a matricei un șir de valori obținut astfel: se parcurg elementele matricei coloană cu coloană. Se numește secvență fibosnek un termen sau o succesiune de termeni aflați pe poziții consecutive în parcurgerea snek, cu proprietatea că fiecare dintre ei este număr Fibonacci. Similar, se numește secvență non-fibosnek un termen sau o succesiune de termeni aflați pe poziții consecutive în parcurgerea snek, cu proprietatea că niciunul dintre ei nu este număr Fibonacci. Lungimea secvenței este egală cu numărul termenilor săi. Suma secvenței este egală cu suma termenilor săi.
Fiind date elementele matricei cu n
linii și m
coloane, să se determine:
1. numărul de numere Fibonacci din matricea dată inițial;
2. suma celei mai lungi secvențe fibosnek ce poate fi obținută, știind că se poate transforma cel mult o secvență non-fibosnek în una fibosnek folosind procedeul explicat mai sus. Dacă se pot obține mai multe astfel de secvențe de lungime maximă, se va alege prima întâlnită în parcurgerea snek a matricei.
OJI 2023, clasa a IX-a
Problema | Fibosnek | Operații I/O |
fibosnek.in /fibosnek.out
|
---|---|---|---|
Limita timp | 0.8 secunde | Limita memorie |
Total: 6 MB
/
Stivă 4 MB
|
Id soluție | #48861305 | Utilizator | |
Fișier | fibosnek.cpp | Dimensiune | 771 B |
Data încărcării | 07 Februarie 2024, 17:43 | Scor / rezultat | Eroare de compilare |
fibosnek.cpp:4:13: error: 'cufere' was not declared in this scope istream fin(cufere.in); ^ fibosnek.cpp:5:14: error: 'cufere' was not declared in this scope ostream fout(cufere.out); ^ fibosnek.cpp: In function 'int main()': fibosnek.cpp:8:43: error: expected initializer before 'n' int a[15001][15001],fib[15001][15001] n, m, c, i, j, k; ^ fibosnek.cpp:9:10: error: 'c' was not declared in this scope fin>>c; ^ fibosnek.cpp:10:10: error: 'n' was not declared in this scope fin>>n; ^ fibosnek.cpp:11:10: error: 'm' was not declared in this scope fin>>m; ^ fibosnek.cpp:12:9: error: 'i' was not declared in this scope for(i=1; i<=n; i++) { ^ fibosnek.cpp:13:13: error: 'j' was not declared in this scope for(j=1; j<=m; j++) { ^ fibosnek.cpp:17:5: error: 'fib' was not declared in this scope fib[1]=1; ^ fibosnek.cpp:19:9: error: 'k' was not declared in this scope for(k=3; k<=m*n; k++) { ^ fibosnek.cpp:23:13: error: 'k' was not declared in this scope for(k=2; k<=n*m; k++) { ^ fibosnek.cpp:24:17: error: 'i' was not declared in this scope for(i=1; i<=n; i++){ ^ fibosnek.cpp:25:21: error: 'j' was not declared in this scope for(j=1; j<=m; j++) { ^ fibosnek.cpp:27:25: error: 'ok' was not declared in this scope ok++; ^ fibosnek.cpp:32:15: error: 'ok' was not declared in this scope fout<<ok; ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Fibosnek 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ă.