Published by
Nov 16, 2013 (last update: Nov 16, 2013)

Recursive linked Hanoy Tower

Score: 2.9/5 (96 votes)
*****

Recursive linked Hanoy Tower


Hello!

Here is my first article, and I think it won't be really great for you because the text in the console is in Spanish, it hasn't comments and it's a bit "cramped" xD. However, I hope you like it :D.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#include <iostream>
#include <fstream>
#include <string>
#include <sstream>
using namespace std;
struct l{
    int v;
    l*next;};
void display(l*l,string&sg){
    char Result[16];
    stringstream ss;
    string f;
    if(l==NULL){cout<<"-"<<endl<<endl;sg+="*\n";}
    else if(l!=NULL){
        sprintf(Result,"%d",l->v);
        ss << Result;
        ss >> f;
        cout<<l->v<<endl;
        sg+=f;
        display(l->next,sg);}}
l* add(l*list,int s){
    l*ob=new l;ob->v=s;
    ob->next=list;return ob;}
void cambiar(l*&l1,l*&l2,l*&l3,int s,int&n,string&sg){
    char Result[16];
    stringstream ss;
    string f;
    if(s==1){int i=(n+3)%3;
            if(i==1){l3=add(l3,l1->v);l1=l1->next;
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l1 a l3\n\n";
                cout<<"Pieza "<<s<<". Cambio de l1 a l3\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}
            else if(i==2){l2=add(l2,l3->v);l3=l3->next;
                cout<<"Pieza "<<s<<". Cambio de l3 a l2\n";
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l3 a l2\n\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}
            else{l1=add(l1,l2->v);l2=l2->next;
                cout<<"Pieza "<<s<<". Cambio de l2 a l1\n";
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l2 a l1\n\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}}
    else{if(s%2==0){int i=(n+3)%3;
            if(i==2){l2=add(l2,l1->v);l1=l1->next;
                cout<<"Pieza "<<s<<". Cambio de l1 a l2\n";
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l1 a l2\n\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}
            else if(i==1){l3=add(l3,l2->v);l2=l2->next;
                cout<<"Pieza "<<s<<". Cambio de l2 a l3\n";
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l2 a l3\n\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}
            else{l1=add(l1,l3->v);l3=l3->next;
                cout<<"Pieza "<<s<<". Cambio de l3 a l1\n";
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l3 a l1\n\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}}
        else{int i=(n+3)%3;
            if(i==0){l3=add(l3,l1->v);l1=l1->next;
                cout<<"Pieza "<<s<<". Cambio de l1 a l3\n";
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l1 a l3\n\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}
            else if(i==1){l2=add(l2,l3->v);l3=l3->next;
                cout<<"Pieza "<<s<<". Cambio de l3 a l2\n";
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l3 a l2\n\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}
            else{l1=add(l1,l2->v);l2=l2->next;
                cout<<"Pieza "<<s<<". Cambio de l2 a l1\n";
                sprintf(Result,"%d",s);
                ss << Result;
                ss >> f;
                sg+="Pieza "+f+". Cambio de l2 a l1\n\n";
                display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";}}}}
void hanoy(l*&l1,l*&l2,l*&l3,int size,int&n1,string&sg){
    if(size==1){cambiar(l1,l2,l3,size,n1,sg);n1++;}
    else{hanoy(l1,l2,l3,size-1,n1,sg);
        cambiar(l1,l2,l3,size,n1,sg);
        hanoy(l1,l2,l3,size-1,n1,sg);}}
int main(){
    string sg="Bienvenido\n";
    l*l1=NULL;l*l2=NULL;l*l3=NULL;
    int s,n=1;int&n1=n;
    ofstream Fp("myfile.txt");
    while(true){
        while(true){
            cout<<"Size? (0 to quit) ";cin>>s;
            if(s<0)cout<<"Invalid value\n";
            else break;}
        if(s==0)break;
        for(int i=s;i>0;i--)l1=add(l1,i);
        sg+="Estado original de los pilares:\n\n";
        display(l1,sg);display(l2,sg);display(l3,sg);sg+="\n";
        sg+="Movimientos:\n";
        hanoy(l1,l2,l3,s,n1,sg);
        cout<<"---------------\n";
        sg+="---------------\n";
        l1=NULL;l2=NULL;l3=NULL;n=1;}
    sg+="Fin de los juegos\n";
    Fp<<sg;
    Fp.close();
    cout<<"The algorithm has been saved in myfile.txt\n";}

Attachments: [Estructuras4.cpp]