Write a Menu Driven Program for Towers of Hanoi and Binary Search in C

By | 03.12.2016

Menu Driven Program for Towers of Hanoi and Binary Search in C


Write a Menu Driven Program for Towers of Hanoi and Binary Search in C. Here’s a Simple Program for Towers of Hanoi and Binary Search in C using switch cases in C Programming Language.

  • In this program, first we create a menu to perform Tower of Hanoi and Binary Search in C.It involves Tower of Hanoi , Binary Search in C and Quit function to exit from the program.
  • We also create two functions : BS( ) for the binary search in C and tower( ) to perform Tower of Hanoi Algorithm.
  • Do while( ) Loop is used to continue iteration n times as long as the users wants to run the program. if the termination condition satisfies, it breaks out the loop and jump to the end of the main function.

Below is the source code for C Program for Towers of Hanoi and Binary Search in C which is successfully compiled and run on Windows System to produce desired output as shown below :


SOURCE CODE : :


#include<stdio.h>
#include<conio.h>

int BS(int [], int ,int ,int );
void tower(int , char , char , char );

int main()
{
    int n,a[50],key,opn,i,pos;
    do
    {

        printf(" \n\n Press 1 -> Binary Search , 2-> Towers of Hanoi 3-> Quit\n");
        scanf("%d",&opn);
        switch(opn)
        {

        case 1:
            printf(" How Many Elements ? ");
            scanf("%d",&n);
            printf(" Read all the elements is ASC order ::\n");

            for(i=1;i<=n;i++)
                scanf("%d",&a[i]);
            printf(" Read the Key (Search) Element :: ");
            scanf("%d",&key);
            pos=BS(a,key,1,n);

            if(pos)
                printf(" Success: %d found at %d \n", key,pos);
            else
             printf(" Falure: %d Not found in the list ! \n",key);
            break;

        case 2:
            printf("\n\n How Many Disks ?");
            scanf("%d", &n);
            printf("\n\n Result of Towers of Hanoi for %d Disks \n",n);

            tower(n,'A','B','C');

            printf("\n\n Note: A-> Source, B-> Intermediate, C-> Destination\n");
            break;

        case 3:
            printf(" Terminating \n");
            break;
        default:
            printf(" Invalid Option !! Try Again !! \n");
        }

        printf(" Press a Key. . . ");
        getch();

    }while(opn != 3);

    return 0;
}
int BS(int a[], int key,int low,int high)
{
    int mid;

    if(low > high)
        return 0; /* failure */
    else
    {
        mid=(low+high)/2;
        if(a[mid]== key)
            return mid; /* Success */
        if(key < a[mid])
          return(BS(a,key,low,mid-1));
        return(BS(a,key,mid+1,high));
    }
}
void tower(int n, char src, char intr, char dst)
{
    if(n > 0)
    {
        tower(n-1,src,dst,intr);

        printf("Move disk %d from %c to %c \n", n,src,dst);

        tower(n-1,intr,src,dst);
    }
}

OUTPUT : :


Press 1 -> Binary Search , 2-> Towers of Hanoi 3-> Quit
1
 How Many Elements ? 6
 Read all the elements is ASC order ::
2
7
23
45
61
87
 Read the Key (Search) Element :: 50
 Falure: 50 Not found in the list !
 Press a Key. . .

 Press 1 -> Binary Search , 2-> Towers of Hanoi 3-> Quit
1
 How Many Elements ? 6
 Read all the elements is ASC order ::
2
5
7
9
34
56
 Read the Key (Search) Element :: 9
 Success: 9 found at 4
 Press a Key. . .

 Press 1 -> Binary Search , 2-> Towers of Hanoi 3-> Quit
2


 How Many Disks ?5


 Result of Towers of Hanoi for 5 Disks
Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B
Move disk 3 from A to C
Move disk 1 from B to A
Move disk 2 from B to C
Move disk 1 from A to C
Move disk 4 from A to B
Move disk 1 from C to B
Move disk 2 from C to A
Move disk 1 from B to A
Move disk 3 from C to B
Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B
Move disk 5 from A to C
Move disk 1 from B to A
Move disk 2 from B to C
Move disk 1 from A to C
Move disk 3 from B to A
Move disk 1 from C to B
Move disk 2 from C to A
Move disk 1 from B to A
Move disk 4 from B to C
Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B
Move disk 3 from A to C
Move disk 1 from B to A
Move disk 2 from B to C
Move disk 1 from A to C


 Note: A-> Source, B-> Intermediate, C-> Destination
 Press a Key. . .

 Press 1 -> Binary Search , 2-> Towers of Hanoi 3-> Quit
3
 Terminating
 Press a Key. . .
Process returned 0

If you found any error or any queries related to the above program or any questions or reviews , you wanna to ask from us ,you may Contact Us through our contact Page or you can also comment below in the comment section.We will try our best to reach upto you in the short interval.


Thanks for reading the post.

0 0 votes
Article Rating
Category: Advance Programs C Programming Tags:

About Tunde A

My name is Tunde Ajetomobi, a Tech Enthusiast and Growth Hacker. I enjoy creating helpful content that solves problem across different topics. Codezclub is my way of helping young aspiring programmers and students to hone their skills and find solutions on fundamental programming languages.

Subscribe
Notify of
guest
0 Comments
Oldest
Newest Most Voted
Inline Feedbacks
View all comments