#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 | #55823990 | Utilizator | |
Fișier | nestemate.cpp | Dimensiune | 2.21 KB |
Data încărcării | 27 Ianuarie 2025, 20:20 | Scor / rezultat | Eroare de compilare |
nestemate.cpp: In function 'int main()': nestemate.cpp:47:18: error: expected unqualified-id before '[' token auto [current, steps] = q.front(); ^ nestemate.cpp:50:17: error: 'current' was not declared in this scope if (current == B) { ^ nestemate.cpp:51:26: error: 'steps' was not declared in this scope result = steps; ^ nestemate.cpp:57:40: error: 'current' was not declared in this scope current_vals.insert(stones[current].x); ^ nestemate.cpp:71:43: error: 'steps' was not declared in this scope q.push({neighbor, steps + 1}); ^ nestemate.cpp:71:53: error: no matching function for call to 'std::queue<std::pair<int, int> >::push(<brace-enclosed initializer list>)' q.push({neighbor, steps + 1}); ^ nestemate.cpp:71:53: note: candidates are: In file included from /usr/include/c++/4.8/queue:64:0, from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:85, from nestemate.cpp:1: /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ă.