#3716
Se dă o matrice de rebus cu n linii și m coloane. Fiecare celulă conține unul dintre caracterele:
'+' – celulă blocată (nu poate conține literă)'-' – celulă liberă (trebuie completată cu o literă)De asemenea, se dă o listă de W cuvinte (formate doar din litere mari A-Z) care trebuie completate în rebus.
Un cuvânt poate fi plasat:
într-un segment maximal de celule '-' consecutive (numit slot). Lungimea cuvântului trebuie să fie egală cu lungimea slotului.
Două cuvinte se pot intersecta (o celulă poate aparține atât unui slot orizontal, cât și unuia vertical), dar în acest caz litera rezultată în acea celulă trebuie să coincidă pentru ambele cuvinte.
Fiecare cuvânt din listă trebuie folosit exact o singură dată.
hackerrank.com (modificată)
| Problema | Crossword | Operații I/O |
crossword.in/crossword.out
|
|---|---|---|---|
| Limita timp | 0.1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 64 MB
|
| Id soluție | #64245661 | Utilizator | |
| Fișier | crossword.cpp | Dimensiune | 2.52 KB |
| Data încărcării | 25 Aprilie 2026, 12:42 | Scor/rezultat | 57 puncte |
crossword.cpp: In function ‘void unplace(std::vector<std::pair<int, int> >&)’: crossword.cpp:35:15: warning: structured bindings only available with ‘-std=c++17’ or ‘-std=gnu++17’ [-Wc++17-extensions] 35 | for (auto [r, c] : changed) grid[r][c] = '-'; | ^ crossword.cpp: In function ‘int main()’: crossword.cpp:55:12: warning: ignoring return value of ‘FILE* freopen(const char*, const char*, FILE*)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 55 | freopen("crossword.in", "r", stdin); | ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~ crossword.cpp:56:12: warning: ignoring return value of ‘FILE* freopen(const char*, const char*, FILE*)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 56 | freopen("crossword.out", "w", stdout); | ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ crossword.cpp:58:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 58 | scanf("%d %d\n", &n, &m); | ~~~~~^~~~~~~~~~~~~~~~~~~ crossword.cpp:59:38: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 59 | for (int i = 0; i < n; i++) scanf("%s", grid[i]); | ~~~~~^~~~~~~~~~~~~~~ crossword.cpp:63:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 63 | scanf("%s", buf); | ~~~~~^~~~~~~~~~~
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 1 | 0.001 secunde | OK. | 5 | 5 | Exemplu | |
| 2 | 0.001 secunde | OK. | 5 | 5 | Exemplu | |
| 3 | 0.001 secunde | OK. | 5 | 5 | Exemplu | |
| 4 | 0.001 secunde | OK. | 2 | 2 | ||
| 5 | 0.002 secunde | OK. | 2 | 2 | ||
| 6 | 0.001 secunde | OK. | 2 | 2 | ||
| 7 | 0.001 secunde | OK. | 2 | 2 | ||
| 8 | 0.001 secunde | OK. | 2 | 2 | ||
| 9 | 0.001 secunde | OK. | 2 | 2 | ||
| 10 | 0.002 secunde | OK. | 2 | 2 | ||
| 11 | 0.001 secunde | OK. | 2 | 2 | ||
| 12 | 0.001 secunde | OK. | 2 | 2 | ||
| 13 | 0.001 secunde | OK. | 2 | 2 | ||
| 14 | 0.002 secunde | OK. | 2 | 2 | ||
| 15 | 0.002 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 16 | 0.004 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 17 | 0.003 secunde | Caught fatal signal 11 | 2 | 0 | ||
| 18 | 0.002 secunde | Caught fatal signal 11 | 2 | 0 | ||
| 19 | 0.005 secunde | Caught fatal signal 11 | 2 | 0 | ||
| 20 | 0.003 secunde | Caught fatal signal 11 | 2 | 0 | ||
| 21 | 0.004 secunde | Caught fatal signal 11 | 5 | 0 | ||
| 22 | 0.005 secunde | Caught fatal signal 11 | 5 | 0 | ||
| 23 | 0.003 secunde | Caught fatal signal 11 | 5 | 0 | ||
| 24 | 0.008 secunde | Caught fatal signal 11 | 5 | 0 | ||
| 25 | 0.001 secunde | OK. | 4 | 4 | ||
| 26 | 0.001 secunde | OK. | 4 | 4 | ||
| 27 | 0.003 secunde | OK. | 4 | 4 | ||
| 28 | 0.002 secunde | Caught fatal signal 11 | 4 | 0 | ||
| 29 | 0.006 secunde | OK. | 4 | 4 | ||
| 30 | 0.002 secunde | OK. | 4 | 4 | ||
| 31 | 0.003 secunde | Caught fatal signal 11 | 4 | 0 | ||
| 32 | 0.002 secunde | Caught fatal signal 11 | 3 | 0 | ||
| Punctaj total | 57 | |||||
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Crossword 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ă.