#2527
hanoi
Turnurile din Hanoi este un joc matematic sau, dacă vreți, un puzzle. Este format din trei tije A
, B
și C
și un număr variabil de discuri, de diferite diametre. Inițial discurile sunt așezate în ordine descrescătoare a diametrelor pe tija A
, de la vârf către bază, astfel încât să formeze un turn.
Scopul jocului este acela de a muta toate discurile de pe tija A
pe tija C
folosind ca tijă intermediară tija B
, respectând următoarele reguli:
Cerința
Dacă se cunoaște numărul n
de discuri aflate pe tija A
, să se determine șirul mutărilor necesare pentru ca toate discurile să fie mutate pe tija C
.
Problema | hanoi | Operații I/O |
hanoi.in /hanoi.out
|
---|---|---|---|
Limita timp | 0.1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #54045967 | Utilizator | |
Fișier | hanoi.cpp | Dimensiune | 602 B |
Data încărcării | 18 Noiembrie 2024, 17:26 | Scor / rezultat | Eroare de compilare |
hanoi.cpp: In function 'void hanoi(int, char, char, char)': hanoi.cpp:12:10: error: reference to 'cout' is ambiguous cout << sursa << "->" << dest << '\n'; ^ hanoi.cpp:6:10: note: candidates are: std::ofstream cout ofstream cout("hanoi.out"); ^ In file included from hanoi.cpp:1:0: /usr/include/c++/4.8/iostream:61:18: note: std::ostream std::cout extern ostream cout; /// Linked to standard output ^ hanoi.cpp: In function 'int main()': hanoi.cpp:23:5: error: reference to 'cin' is ambiguous cin >> k; ^ hanoi.cpp:5:10: note: candidates are: std::ifstream cin ifstream cin("hanoi.in"); ^ In file included from hanoi.cpp:1:0: /usr/include/c++/4.8/iostream:60:18: note: std::istream std::cin extern istream cin; /// Linked to standard input ^ hanoi.cpp:26:5: error: reference to 'cout' is ambiguous cout << ( 1 << k) - 1 << '\n'; ^ hanoi.cpp:6:10: note: candidates are: std::ofstream cout ofstream cout("hanoi.out"); ^ In file included from hanoi.cpp:1:0: /usr/include/c++/4.8/iostream:61:18: note: std::ostream std::cout extern ostream cout; /// Linked to standard output ^ hanoi.cpp:25:9: warning: unused variable 'put' [-Wunused-variable] int put = 1; ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema hanoi 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ă.