#4613
Dominic este un alchimist renumit pentru experimentele sale cu pietre preţioase. De-a lungul carierei sale a reușit să strângă o colecție de N
nestemate pe care le-a numerotat de la 1
la N
. Conform studiilor sale, aspectul fiecărei nestemate este caracterizat prin trei întregi X, Y
și Z
reprezentând culoarea, claritatea şi strălucirea acesteia.
Dominic a descoperit o metodă secretă prin care poate face o nestemată din colecția sa să capete aspectul unei alte nestemate din colecţie. Metoda are însă o slăbiciune, reuşind dacă şi numai dacă cel puţin una din valorile primei nestemate este egală cu cel puţin una dintre valorile celeilalte nestemate, dar este irelevant dacă proprietatea pe care o reprezintă cele două valori coincide. De exemplu, nestemata (1, 3, 4)
poate fi transformată în nestemata (3, 2, 2)
deoarece ambele au una din proprietăţi egală cu 3
.
Se dau numărul de teste T
şi pentru fiecare test N
, A
şi B
şi proprietăţilor celor N
nestemate din colecţia lui Dominic. Se cere să se afle numărul minim de transformări necesare (dacă este posibil).
OJI 2024, clasele 11-12
Problema | nestemate | Operații I/O |
![]() nestemate.in /nestemate.out
|
---|---|---|---|
Limita timp | 0.6 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #57744198 | Utilizator | |
Fișier | nestemate.cpp | Dimensiune | 1.78 KB |
Data încărcării | 14 Aprilie 2025, 08:00 | Scor / rezultat | Eroare de compilare |
nestemate.cpp: In function 'int minTransformari(int, int, int, std::vector<Nestemata>&)': nestemate.cpp:15:14: error: expected unqualified-id before '[' token auto [x, y, z] = nestemate[i]; ^ nestemate.cpp:16:27: error: 'x' was not declared in this scope valoare_la_noduri[x].push_back(i); ^ nestemate.cpp:17:27: error: 'y' was not declared in this scope valoare_la_noduri[y].push_back(i); ^ nestemate.cpp:18:27: error: 'z' was not declared in this scope valoare_la_noduri[z].push_back(i); ^ nestemate.cpp:27:14: error: expected unqualified-id before '[' token auto [curent, distanta] = q.front(); q.pop(); ^ nestemate.cpp:28:13: error: 'curent' was not declared in this scope if (curent == B) return distanta; ^ nestemate.cpp:28:33: error: 'distanta' was not declared in this scope if (curent == B) return distanta; ^ nestemate.cpp:30:27: error: 'curent' was not declared in this scope int x = nestemate[curent].x; ^ nestemate.cpp:39:40: error: 'distanta' was not declared in this scope q.push({vecin, distanta + 1}); ^ nestemate.cpp:39:53: error: no matching function for call to 'std::queue<std::pair<int, int> >::push(<brace-enclosed initializer list>)' q.push({vecin, distanta + 1}); ^ nestemate.cpp:39:53: note: candidates are: In file included from /usr/include/c++/4.8/queue:64:0, from nestemate.cpp:5: /usr/include/c++/4.8/bits/stl_queue.h:212:7: note: void std::queue<_Tp, _Sequence>::push(const value_type&) [with _Tp = std::pair<int, int>; _Sequence = std::deque<std::pair<int, int>, std::allocator<std::pair<int, int> > >; std::queue<_Tp, _Sequence>::value_type = std::pair<int, int>] push(const value_type& __x) ^ /usr/include/c++/4.8/bits/stl_queue.h:212:7: note: no known conversion for argument 1 from '<brace-enclosed initializer list>' to 'const value_type& {aka const std::pair<int, int>&}' /usr/include/c++/4.8/bits/stl_queue.h:217:7: note: void std::queue<_Tp, _Sequence>::push(std::queue<_Tp, _Sequence>::value_type&&) [with _Tp = std::pair<int, int>; _Sequence = std::deque<std::pair<int, int>, std::allocator<std::pair<int, int> > >; std::queue<_Tp, _Sequence>::value_type = std::pair<int, int>] push(value_type&& __x) ^ /usr/include/c++/4.8/bits/stl_queue.h:217:7: note: no known conversion for argument 1 from '<brace-enclosed initializer list>' to 'std::queue<std::pair<int, int> >::value_type&& {aka std::pair<int, int>&&}'
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema nestemate 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ă.