Fişierul intrare/ieşire:hanoi.in, hanoi.outSursăinfoarena 2.0
AutorDin FolclorAdăugată defilipbFilip Cristian Buruiana filipb
Timp execuţie pe test0.2 secLimită de memorie20480 kbytes
Scorul tăuN/ADificultateN/A

Vezi solutiile trimise | Statistici

Hanoi

Problema turnurilor din Hanoi este bine cunoscută: sunt 3 tije şi N discuri, oricare două discuri având raza diferită. Iniţial, cele N discuri sunt aşezate pe prima tijă, discurile fiind ordonate de jos în sus descrescător în funcţie de rază. Astfel, discul cu raza cea mai mare este cel mai de jos iar discul cu raza cea mai mică cel mai de sus. Se doreşte mutarea discurilor de pe prima pe ultima tijă, efectuând un număr minim de mutări. O mutare constă în alegerea unei tije care conţine cel puţin un disc şi mutarea discului din vârf în vârful oricărei alte tije. Singura regulă este că un disc nu poate fi aşezat peste alt disc de rază mai mică.

Există o legendă conform căreia într-o mănăstire din Tibet călugării au aşezat N discuri pe prima tijă iar apoi au început să efectueze mutări astfel încât să le mute pe ultima tijă. Legenda spune că atunci când vor termina va avea loc sfârşitul lumii. Recent s-a descoperit că de fapt călugării foloseau M tije în loc de 3 şi că sfârşitul lumii s-ar putea să fie de fapt mult mai aproape.

Să se determine numărul minim de paşi pentru a muta cele N discuri de pe prima pe ultima tijă, ştiind că în total sunt M tije care pot fi folosite.

Date de intrare

Fişierul de intrare hanoi.in conţine pe prima linie, separate de exact un spatiu, numerele N si M, cu semnificaţia din enunţ.

Date de ieşire

Fişierul de ieşire hanoi.out conţine o singură linie pe care se află răspunsul problemei.

Restricţii

  • 3 ≤ N ≤ 250
  • 3 ≤ M ≤ 150

Exemple

hanoi.inhanoi.out
5 413

Explicaţie

Mai jos este prezentată o secvenţă posibilă cu numar minim de mutări pentru a aduce discurile de pe tija iniţială pe cea finală:

În total au fost efectuate 13 mutări.

Trebuie sa te autentifici pentru a trimite solutii. Click aici

Cum se trimit solutii?

remote content