Software & Finance





Turbo C - Tower Of Hanoi Algorithm Source Code





You can find the complete Turbo C source code for Tower of Hanoi algorithm. Given the number of discs as input, you can get the print out of the list of steps you need to solve the problem.

 

This program is developed in Turbo C application and takes the number of discs as input. It uses recursive logic to find the number of steps required to solve thr problem. I have implemented my own stack. Initially the discs are getting added into the stack. I have 3 stacks A, B and C for 3 towers A, B and C. The function SolveTOH is used to compute all possible steps to solve the problem. Note that it uses the recursive logic and the output after each move is written on the screen.

 

The Big O notation for this problem is: 2^n - 1.

 

The other related links are given below:

 

The complete turbo source code and executable can be found at the end of the page.

 


Source Code


  

#include <stdio.h>

#include <alloc.h>

#include <stdlib.h>

#include <string.h>

 

typedef struct _MyStack

{

    int *m_data;

    int m_numElements;

} MyStack;

 

 

static int movecount = 0;

static int countA = 0;

static int countB = 0;

static int countC = 0;

 

static MyStack *A = 0;

static MyStack *B = 0;

static MyStack *C = 0;

 

int push(MyStack *s, int data)

{

      if(s->m_data == NULL) // root node

      {

          s->m_numElements = 1;

          s->m_data = (int*) malloc(sizeof(int));

      }

      else

      {

          s->m_numElements++;

          s->m_data = realloc(s->m_data, s->m_numElements * sizeof(int));

          memmove(&s->m_data[1], s->m_data, (s->m_numElements - 1) * sizeof(int));

      }

 

      s->m_data[0] = data;

      return 1;

}

 

int pop(MyStack *s)

{

    int result = -1;

      if(s->m_data == NULL) // root node

      {

            s->m_numElements = 0;

            return result;

      }

      else

      {

        result = top(s);

          if(s->m_numElements == 1)

          {

            // last item

                s->m_numElements = 0;

                free(s->m_data);

                s->m_data = NULL;

          }

          else

          {

                s->m_numElements--;

                memmove(s->m_data, &s->m_data[1], s->m_numElements * sizeof(int));

                s->m_data = (int*) realloc(s->m_data, s->m_numElements * sizeof(int));

          }

      }

      return result;

}

 

int top(MyStack *s)

{

      if(s->m_numElements > 0)

          return s->m_data[0];

      return 0;

}

 

int size(MyStack *s)

{

      return s->m_numElements;

}

 

void PrintStack(MyStack *s)

{

    int i = 0;

    printf("[");

    for(i = s->m_numElements - 1; i >= 0; i--)

    {

        printf("%d", s->m_data[i]);

    }

    printf("]");

}

 

void PrintStacks()

{

    if (countA != A->m_numElements ||

        countB != B->m_numElements ||

        countC != C->m_numElements)

    {

        int diffA = A->m_numElements - countA;

        int diffB = B->m_numElements - countB;

        int diffC = C->m_numElements - countC;

        if (diffA == 1)

        {

            if (diffB == -1)

                printf("Move Disc %d From B To A", top(A));

            else

                printf("Move Disc %d From C To A", top(A));

        }

        else if (diffB == 1)

        {

            if (diffA == -1)

                printf("Move Disc %d From A To B", top(B));

            else

                printf("Move Disc %d From C To B", top(B));

        }

        else //if (diffC == 1)

        {

            if (diffA == -1)

                printf("Move Disc %d From A To C", top(C));

            else

                printf("Move Disc %d From B To C", top(C));

        }

        countA = A->m_numElements;

        countB = B->m_numElements;

        countC = C->m_numElements;

        printf("\n");

    }

 

    PrintStack(A);

    printf(" , ");

    PrintStack(B);

    printf(" , ");

    PrintStack(C);

    printf(" , ");

}

 

void Solve2DiscsTOH(MyStack *source, MyStack *temp, MyStack *dest)

{           

    push(temp, pop(source));

    movecount++;

    PrintStacks();

 

    push(dest, pop(source));

    movecount++;

    PrintStacks();

 

    push(dest, pop(temp));

    movecount++;

    PrintStacks();

}

 

int SolveTOH(int nDiscs, MyStack *source, MyStack *temp, MyStack *dest)

{

    if (nDiscs <= 4)

    {

        if ((nDiscs % 2) == 0)

        {

            Solve2DiscsTOH(source, temp, dest);

            nDiscs = nDiscs - 1;

            if (nDiscs == 1)

                return 1;

 

            push(temp, pop(source));

            movecount++;

            PrintStacks();

            //new source is dest, new temp is source, new dest is temp;

            Solve2DiscsTOH(dest, source, temp);

 

            push(dest, pop(source));

            movecount++;

            PrintStacks();

            //new source is temp, new temp is source, new dest is dest;

            SolveTOH(nDiscs, temp, source, dest);

        }

        else

        {

            if (nDiscs == 1)

                return 0;

            Solve2DiscsTOH(source, dest, temp);

            nDiscs = nDiscs - 1;

            push(dest, pop(source));

            movecount++;

            PrintStacks();

            Solve2DiscsTOH(temp, source, dest);

        }

        return 1;

    }

    else if (nDiscs >= 5)

    {

        SolveTOH(nDiscs - 2, source, temp, dest);

        push(temp, pop(source));

        movecount++;

        PrintStacks();

        SolveTOH(nDiscs - 2, dest, source, temp);

        push(dest, pop(source));

        movecount++;

        PrintStacks();

        SolveTOH(nDiscs - 1, temp, source, dest);

    }

    return 1;

}

 

int main()

{

    int sz, i, maxdisc;

    A = malloc(sizeof(MyStack));

    B = malloc(sizeof(MyStack));

    C = malloc(sizeof(MyStack));

 

    while(1)

    {

        printf("\nEnter the number of discs (-1 to exit): ");

        scanf("%d", &maxdisc);

        if(maxdisc == -1)

            break;

        if(maxdisc < 2 || maxdisc > 9)

        {

            printf("Enter between 2 - 9");

            continue;

        }

 

        movecount = 0;

        memset((void*)A, 0, sizeof(MyStack));

        memset((void*)B, 0, sizeof(MyStack));

        memset((void*)C, 0, sizeof(MyStack));

        for (i = maxdisc; i >= 1; i--)

            push(A, i);

        countA = A->m_numElements;

        countB = B->m_numElements;

        countC = C->m_numElements;

        PrintStacks();

        SolveTOH(maxdisc, A, B, C);

        printf("Total Moves = %d", movecount);

        free(C->m_data);

    }

 

    return 0;

}

 

 

Click here to download the Turbo C Source Code and executable

 

 

Output


Enter the number of discs (-1 to exit): 0

Enter between 2 - 9

 

 

Enter the number of discs (-1 to exit): 1

Enter between 2 - 9

 

 

Enter the number of discs (-1 to exit): 2

[21] , [] , [] , Move Disc 1 From A To B

[2] , [1] , [] , Move Disc 2 From A To C

[] , [1] , [2] , Move Disc 1 From B To C

[] , [] , [21] , Total Moves = 3

 

 

Enter the number of discs (-1 to exit): 3

[321] , [] , [] , Move Disc 1 From A To C

[32] , [] , [1] , Move Disc 2 From A To B

[3] , [2] , [1] , Move Disc 1 From C To B

[3] , [21] , [] , Move Disc 3 From A To C

[] , [21] , [3] , Move Disc 1 From B To A

[1] , [2] , [3] , Move Disc 2 From B To C

[1] , [] , [32] , Move Disc 1 From A To C

[] , [] , [321] , Total Moves = 7

 

 

Enter the number of discs (-1 to exit): 4

[4321] , [] , [] , Move Disc 1 From A To B

[432] , [1] , [] , Move Disc 2 From A To C

[43] , [1] , [2] , Move Disc 1 From B To C

[43] , [] , [21] , Move Disc 3 From A To B

[4] , [3] , [21] , Move Disc 1 From C To A

[41] , [3] , [2] , Move Disc 2 From C To B

[41] , [32] , [] , Move Disc 1 From A To B

[4] , [321] , [] , Move Disc 4 From A To C

[] , [321] , [4] , Move Disc 1 From B To C

[] , [32] , [41] , Move Disc 2 From B To A

[2] , [3] , [41] , Move Disc 1 From C To A

[21] , [3] , [4] , Move Disc 3 From B To C

[21] , [] , [43] , Move Disc 1 From A To B

[2] , [1] , [43] , Move Disc 2 From A To C

[] , [1] , [432] , Move Disc 1 From B To C

[] , [] , [4321] , Total Moves = 15

 

 

Enter the number of discs (-1 to exit): 5

[54321] , [] , [] , Move Disc 1 From A To C

[5432] , [] , [1] , Move Disc 2 From A To B

[543] , [2] , [1] , Move Disc 1 From C To B

[543] , [21] , [] , Move Disc 3 From A To C

[54] , [21] , [3] , Move Disc 1 From B To A

[541] , [2] , [3] , Move Disc 2 From B To C

[541] , [] , [32] , Move Disc 1 From A To C

[54] , [] , [321] , Move Disc 4 From A To B

[5] , [4] , [321] , Move Disc 1 From C To B

[5] , [41] , [32] , Move Disc 2 From C To A

[52] , [41] , [3] , Move Disc 1 From B To A

[521] , [4] , [3] , Move Disc 3 From C To B

[521] , [43] , [] , Move Disc 1 From A To C

[52] , [43] , [1] , Move Disc 2 From A To B

[5] , [432] , [1] , Move Disc 1 From C To B

[5] , [4321] , [] , Move Disc 5 From A To C

[] , [4321] , [5] , Move Disc 1 From B To A

[1] , [432] , [5] , Move Disc 2 From B To C

[1] , [43] , [52] , Move Disc 1 From A To C

[] , [43] , [521] , Move Disc 3 From B To A

[3] , [4] , [521] , Move Disc 1 From C To B

[3] , [41] , [52] , Move Disc 2 From C To A

[32] , [41] , [5] , Move Disc 1 From B To A

[321] , [4] , [5] , Move Disc 4 From B To C

[321] , [] , [54] , Move Disc 1 From A To C

[32] , [] , [541] , Move Disc 2 From A To B

[3] , [2] , [541] , Move Disc 1 From C To B

[3] , [21] , [54] , Move Disc 3 From A To C

[] , [21] , [543] , Move Disc 1 From B To A

[1] , [2] , [543] , Move Disc 2 From B To C

[1] , [] , [5432] , Move Disc 1 From A To C

[] , [] , [54321] , Total Moves = 31

 

 

Enter the number of discs (-1 to exit): 6

[654321] , [] , [] , Move Disc 1 From A To B

[65432] , [1] , [] , Move Disc 2 From A To C

[6543] , [1] , [2] , Move Disc 1 From B To C

[6543] , [] , [21] , Move Disc 3 From A To B

[654] , [3] , [21] , Move Disc 1 From C To A

[6541] , [3] , [2] , Move Disc 2 From C To B

[6541] , [32] , [] , Move Disc 1 From A To B

[654] , [321] , [] , Move Disc 4 From A To C

[65] , [321] , [4] , Move Disc 1 From B To C

[65] , [32] , [41] , Move Disc 2 From B To A

[652] , [3] , [41] , Move Disc 1 From C To A

[6521] , [3] , [4] , Move Disc 3 From B To C

[6521] , [] , [43] , Move Disc 1 From A To B

[652] , [1] , [43] , Move Disc 2 From A To C

[65] , [1] , [432] , Move Disc 1 From B To C

[65] , [] , [4321] , Move Disc 5 From A To B

[6] , [5] , [4321] , Move Disc 1 From C To A

[61] , [5] , [432] , Move Disc 2 From C To B

[61] , [52] , [43] , Move Disc 1 From A To B

[6] , [521] , [43] , Move Disc 3 From C To A

[63] , [521] , [4] , Move Disc 1 From B To C

[63] , [52] , [41] , Move Disc 2 From B To A

[632] , [5] , [41] , Move Disc 1 From C To A

[6321] , [5] , [4] , Move Disc 4 From C To B

[6321] , [54] , [] , Move Disc 1 From A To B

[632] , [541] , [] , Move Disc 2 From A To C

[63] , [541] , [2] , Move Disc 1 From B To C

[63] , [54] , [21] , Move Disc 3 From A To B

[6] , [543] , [21] , Move Disc 1 From C To A

[61] , [543] , [2] , Move Disc 2 From C To B

[61] , [5432] , [] , Move Disc 1 From A To B

[6] , [54321] , [] , Move Disc 6 From A To C

[] , [54321] , [6] , Move Disc 1 From B To C

[] , [5432] , [61] , Move Disc 2 From B To A

[2] , [543] , [61] , Move Disc 1 From C To A

[21] , [543] , [6] , Move Disc 3 From B To C

[21] , [54] , [63] , Move Disc 1 From A To B

[2] , [541] , [63] , Move Disc 2 From A To C

[] , [541] , [632] , Move Disc 1 From B To C

[] , [54] , [6321] , Move Disc 4 From B To A

[4] , [5] , [6321] , Move Disc 1 From C To A

[41] , [5] , [632] , Move Disc 2 From C To B

[41] , [52] , [63] , Move Disc 1 From A To B

[4] , [521] , [63] , Move Disc 3 From C To A

[43] , [521] , [6] , Move Disc 1 From B To C

[43] , [52] , [61] , Move Disc 2 From B To A

[432] , [5] , [61] , Move Disc 1 From C To A

[4321] , [5] , [6] , Move Disc 5 From B To C

[4321] , [] , [65] , Move Disc 1 From A To B

[432] , [1] , [65] , Move Disc 2 From A To C

[43] , [1] , [652] , Move Disc 1 From B To C

[43] , [] , [6521] , Move Disc 3 From A To B

[4] , [3] , [6521] , Move Disc 1 From C To A

[41] , [3] , [652] , Move Disc 2 From C To B

[41] , [32] , [65] , Move Disc 1 From A To B

[4] , [321] , [65] , Move Disc 4 From A To C

[] , [321] , [654] , Move Disc 1 From B To C

[] , [32] , [6541] , Move Disc 2 From B To A

[2] , [3] , [6541] , Move Disc 1 From C To A

[21] , [3] , [654] , Move Disc 3 From B To C

[21] , [] , [6543] , Move Disc 1 From A To B

[2] , [1] , [6543] , Move Disc 2 From A To C

[] , [1] , [65432] , Move Disc 1 From B To C

[] , [] , [654321] , Total Moves = 63 

 

 

Enter the number of discs (-1 to exit): -1