#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 | #56313333 | Utilizator | |
Fișier | nestemate.cpp | Dimensiune | 2.87 KB |
Data încărcării | 13 Februarie 2025, 13:32 | Scor / rezultat | 100 puncte |
nestemate.cpp:3:0: warning: ignoring #pragma optimize [-Wunknown-pragmas] #pragma optimize ("O3") ^ nestemate.cpp:4:0: warning: ignoring #pragma optimize [-Wunknown-pragmas] #pragma optimize ("inline,unroll-loops,fast-math") ^ nestemate.cpp:5:0: warning: ignoring #pragma optimize [-Wunknown-pragmas] #pragma optimize ("avx2,bmi,bmi2,popcnt,lzcnt") ^ nestemate.cpp: In member function 'char inParser::readChar()': nestemate.cpp:15:51: warning: ignoring return value of 'size_t fread(void*, size_t, size_t, FILE*)', declared with attribute warn_unused_result [-Wunused-result] id = 0; fread(buff, sizeof( char ), 4096, fin); ^ nestemate.cpp: In function 'void solve()': nestemate.cpp:54:14: warning: 'startNode.node::nodeC' may be used uninitialized in this function [-Wmaybe-uninitialized] node startNode, endNode; ^ nestemate.cpp:54:14: warning: 'startNode.node::nodeB' may be used uninitialized in this function [-Wmaybe-uninitialized] nestemate.cpp:54:14: warning: 'startNode.node::nodeA' may be used uninitialized in this function [-Wmaybe-uninitialized] nestemate.cpp:84:39: warning: 'endNode.node::nodeC' may be used uninitialized in this function [-Wmaybe-uninitialized] ans = distanceTo[endNode.nodeC] ? min(ans, distanceTo[endNode.nodeC]) : ans; ^ nestemate.cpp:82:39: warning: 'endNode.node::nodeA' may be used uninitialized in this function [-Wmaybe-uninitialized] ans = distanceTo[endNode.nodeA] ? min(ans, distanceTo[endNode.nodeA]) : ans; ^ nestemate.cpp:83:39: warning: 'endNode.node::nodeB' may be used uninitialized in this function [-Wmaybe-uninitialized] ans = distanceTo[endNode.nodeB] ? min(ans, distanceTo[endNode.nodeB]) : ans; ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0 secunde | OK. | 11 | 11 | ||
2 | 0 secunde | OK. | 13 | 13 | ||
3 | 0 secunde | OK. | 16 | 16 | ||
4 | 0 secunde | OK. | 10 | 10 | ||
5 | 0 secunde | OK. | 10 | 10 | ||
6 | 0.056 secunde | OK. | 7 | 7 | ||
7 | 0.08 secunde | OK. | 6 | 6 | ||
8 | 0.08 secunde | OK. | 9 | 9 | ||
9 | 0.08 secunde | OK. | 9 | 9 | ||
10 | 0.1 secunde | OK. | 9 | 9 | ||
Punctaj total | 100 |
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ă.