Your SlideShare is downloading. ×
Torres de hanoi
Torres de hanoi
Upcoming SlideShare
Loading in...5
×

Thanks for flagging this SlideShare!

Oops! An error has occurred.

×
Saving this for later? Get the SlideShare app to save on your phone or tablet. Read anywhere, anytime – even offline.
Text the download link to your phone
Standard text messaging rates apply

Torres de hanoi

123

Published on

Published in: Technology
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
123
On Slideshare
0
From Embeds
0
Number of Embeds
0
Actions
Shares
0
Downloads
1
Comments
0
Likes
0
Embeds 0
No embeds

Report content
Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
No notes for slide

Transcript

  • 1. ESCUELA POLITECNICA NACIONALFacultad de ingeniería en sistemasEstructura de datosNombre: Alexander PinchaoTema: Torres de HanóiDefinición.-Las Torres de Hanói es un rompecabezas o juego matemático inventado en 1883 por elmatemático francés Édouard Lucas. Este solitario se trata de un juego de ocho discos de radiocreciente que se apilan insertándose en una de las tres estacas de un tablero. El objetivo del juegoes crear la pila en otra de las estacas siguiendo unas ciertas reglas. El problema es muy conocidoen la ciencia de la computación y aparece en muchos libros de texto como introducción a la teoríade algoritmos.Planificación.-Descripción.-El juego, en su forma más tradicional, consiste en tres varillas verticales. En una de las varillas seapila un número indeterminado de discos (elaborados de madera) que determinará la complejidadde la solución, por regla general se consideran ocho discos. Los discos se apilan sobre una varillaen tamaño decreciente. No hay dos discos iguales, y todos ellos están apilados de mayor a menorradio en una de las varillas, quedando las otras dos varillas vacantes. El juego consiste en pasartodos los discos de la varilla ocupada (es decir la que posee la torre) a una de las otras varillasvacantes. Para realizar este objetivo, es necesario seguir tres simples reglas:Sólo se puede mover un disco cada vez.Un disco de mayor tamaño no puede descansar sobre uno más pequeño que él mismo.Sólo puedes desplazar el disco que se encuentre arriba en cada varilla.Existen diversas formas de realizar la solución final, todas ellas siguiendo estrategias diversas.FUNCION HANOICondiciones.-Para tener un tiempo de procesamiento optimo con números enteros el valor no debe sermayor a 13No acepta stringsNo acepta fraccionesNo acepta números negativosParámetros.-Entrada.- Entero nSalida.- StringRetorno.- NONEEscenarios.-10.- si número mayor que 0 ir a 3020.- mensaje el número es erróneo30.-si número no es mayor a 1 ir a 50
  • 2. 40.- retornar movimiento50.- salir60.-retornar movimiento70.-reducir el valor de número una unidad80.-ir a 30Código fuente.-/// Towers of Hanoi.cpp: archivo de proyecto principal.#include"stdafx.h"#include"iostream"#include"math.h"usingnamespace System;usingnamespacestd;voidhanoi(intnum,charA,charC,char B){if(num==1){cout<<"Mueva el bloque "<<num<<" desde "<<A<<" hasta "<<C<<endl;}else {hanoi(num-1,A,B,C);cout<<"Mueva el bloque "<<num<<" desde "<<A<<" hasta "<<C<<endl;hanoi(num-1,B,C,A);}}int main(array<System::String ^> ^args){intn,opcion;char A,B,C;do{cout<<"1.-Resolver Torre de hanoi.n2.-Salir.n Opcion: ";cin>>opcion;if(opcion==1){cout<<"Los clavijas son A B Cn";cout<<"Numero de discos: ";cin>>n;hanoi(n,A,C,B);}}while(opcion!=0);system("pause");return 0;}

×