#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 | #64768685 | Utilizator | |
| Fișier | crossword.cpp | Dimensiune | 2.57 KB |
| Data încărcării | 28 Mai 2026, 21:05 | Scor/rezultat | 0 puncte |
crossword.cpp: In function ‘int crossLen(std::vector<std::__cxx11::basic_string<char> >&, int&, int&, int, int, int, char)’: crossword.cpp:8:23: warning: statement has no effect [-Wunused-value] 8 | if(dir == 'l')for(j; j<rlen; j++) if (r[i][j] != '+') len++; else break; | ^ crossword.cpp:9:14: warning: statement has no effect [-Wunused-value] 9 | else for(i; i<N; i++) if (r[i][j] != '+') len++; else break; | ^ crossword.cpp: In function ‘void fillCross(std::vector<std::__cxx11::basic_string<char> >&, int&, int&, std::vector<std::__cxx11::basic_string<char> >&)’: crossword.cpp:17:25: warning: comparison of integer expressions of different signedness: ‘int’ and ‘std::__cxx11::basic_string<char>::size_type’ {aka ‘long unsigned int’} [-Wsign-compare] 17 | for(int j = 0; j<r[i].size(); j++){ | ~^~~~~~~~~~~~ crossword.cpp:19:35: warning: comparison of integer expressions of different signedness: ‘int’ and ‘std::__cxx11::basic_string<char>::size_type’ {aka ‘long unsigned int’} [-Wsign-compare] 19 | char dir = (j + 1 < r[i].size() && (r[i][j+1] == '-' || r[i][j+1] != '+')) ? 'l' : 'd'; | ~~~~~~^~~~~~~~~~~~~ crossword.cpp:22:35: warning: comparison of integer expressions of different signedness: ‘int’ and ‘std::vector<std::__cxx11::basic_string<char> >::size_type’ {aka ‘long unsigned int’} [-Wsign-compare] 22 | for (int k = 0; k < w.size(); k++) | ~~^~~~~~~~~~ crossword.cpp: In function ‘int main()’: crossword.cpp:71:26: warning: comparison of integer expressions of different signedness: ‘std::vector<std::__cxx11::basic_string<char> >::size_type’ {aka ‘long unsigned int’} and ‘int’ [-Wsign-compare] 71 | if (words.size() <= i) words.push_back(""); | ~~~~~~~~~~~~~^~~~
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 1 | 0.001 secunde | Caught fatal signal 6 | 5 | 0 | Exemplu | |
| 2 | 0.001 secunde | Caught fatal signal 6 | 5 | 0 | Exemplu | |
| 3 | 0.002 secunde | Caught fatal signal 6 | 5 | 0 | Exemplu | |
| 4 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 5 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 6 | 0.002 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 7 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 8 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 9 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 10 | 0.002 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 11 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 12 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 13 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 14 | 0.003 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 15 | 0.002 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 16 | 0.003 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 17 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 18 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 19 | 0.002 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 20 | 0.001 secunde | Caught fatal signal 6 | 2 | 0 | ||
| 21 | 0.001 secunde | Caught fatal signal 6 | 5 | 0 | ||
| 22 | 0.001 secunde | Caught fatal signal 6 | 5 | 0 | ||
| 23 | 0.001 secunde | Caught fatal signal 6 | 5 | 0 | ||
| 24 | 0.001 secunde | Caught fatal signal 6 | 5 | 0 | ||
| 25 | 0.001 secunde | Caught fatal signal 6 | 4 | 0 | ||
| 26 | 0.001 secunde | Caught fatal signal 6 | 4 | 0 | ||
| 27 | 0.002 secunde | Caught fatal signal 6 | 4 | 0 | ||
| 28 | 0.001 secunde | Caught fatal signal 6 | 4 | 0 | ||
| 29 | 0.001 secunde | Caught fatal signal 6 | 4 | 0 | ||
| 30 | 0.003 secunde | Caught fatal signal 6 | 4 | 0 | ||
| 31 | 0.002 secunde | Caught fatal signal 6 | 4 | 0 | ||
| 32 | 0.001 secunde | Caught fatal signal 6 | 3 | 0 | ||
| Punctaj total | 0 | |||||
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ă.