Question

In: Computer Science

Program a solver for the Towers of Hanoi problem presented below. Submit the following to canvas:...

Program a solver for the Towers of Hanoi problem presented below. Submit the
following to canvas: Hanoi.java, Driver.java (contains your main method). This is an
individual project. Students may discuss solutions to the problem but may not share code
with one another. I will discuss this project during our next lecture.
Rules:
a) There are three Pillars (Pillar1, Pillar2, Pillar3).
b) There are N number of disks of increasing size (disk size is indicated by an integer).
c) At the start, all disks are stacked on one of the pillars.
d) At no point can a disk of larger size be placed above a disk of smaller size (including
the start state).
e) You have to move all disks from the start pillar to a target pillar.
f) Only one disk can be moved at a time.

Sample Run:
Hanoi mySolver = new Hanoi(3,1,3);
//the first parameter is the number of disks
//the second parameter is the start pillar
//the third parameter is the target

The output should be:
My Solution is:

t0 Pillar1: 3 2 1
t0 Pillar2:
t0 Pillar3:
t1 Pillar1: 3 2
t1 Pillar2:
t1 Pillar3: 1
t2 Pillar1: 3
t2 Pillar2: 2
t2 Pillar3: 1
t3 Pillar1: 3
t3 Pillar2: 2 1
t3 Pillar3:
t4 Pillar1:
t4 Pillar2: 2 1
t4 Pillar3: 3
t5 Pillar1: 1
t5 Pillar2: 2
t5 Pillar3: 3
t6 Pillar1: 1
t6 Pillar2:
t6 Pillar3: 3 2
t7 Pillar1:
t7 Pillar2:
t7 Pillar3: 3 2 1

Solutions

Expert Solution

Tower of hanoi problem is quite simple if you understand the pattern.

Let us name three pillars as startPillar, endPillar, tempPillar where startPillar is the pillar from where we need to shift the disk, endPillar is pillar to which we have to shift all the pillars, and tempPillar is a pillar used as an intermediate pillar to store the disks. When you do an exercise of transferring 3 disks from pillar1 to pillar3 using pillar2, you will notice that there is a pattern,

  • first we shift 2 disc from pillar1 to pillar2 (another tower of hanoi problem, but endPillar exchanges its place with tempPillar)
  • then we shift last disc from pillar1 to pillar3
  • then we need to shift 2disc from pillar2 to pillar3 (another tower of hanoi problem, but startPillar exchanges its place with tempPillar)

In general, we can conclude the algorithm that,

  • shift (n-1) disc from pillar1 to pillar2 using pillar3
  • shift 1 disc from pillar1 to pillar3
  • shift (n-1) disc from pillar2 to pillar3 using pillar1

This can be achieved using recursion. we need to call the same problem, but with different pillar positions.

I have given an example of such a recursive function solution below with appropriate comments that will help with your understanding.

To store the discs at any point, I have used stack data structure, as adding and removing of disc from a pillar is in a form of stack, LIFO.

Driver.java

public class Driver {
    public static void main(String[] args) {
        Hanoi h = new Hanoi(3, 1, 3);
    }
}

Hanoi.java

import java.util.Stack;

public class Hanoi {
    // array of stacks to store the disc contents for all the pillars
    public static Stack<Integer>[] pillar = new Stack[4];

    // stepcount to measure the number of steps
    public int stepCount = 0;

    Hanoi(int numOfDisc, int startPillar, int endPillar) {

        pillar[1] = new Stack<Integer>();
        pillar[2] = new Stack<Integer>();
        pillar[3] = new Stack<Integer>();

        // initially push everything in pillar1
        for (int disc = numOfDisc; disc > 0; disc--)
            pillar[startPillar].push(disc);

        int tempPillar = 0;
        // set the position of tempPillar
        if (startPillar == 1 && endPillar == 2)
            tempPillar = 3;
        if (startPillar == 2 && endPillar == 3)
            tempPillar = 1;
        if (startPillar == 1 && endPillar == 3)
            tempPillar = 2;

        // print initial state
        print();
        solveHanoi(numOfDisc, startPillar, endPillar, tempPillar);
    };

    // hanoi solver using the algorithm mentioned above
    void solveHanoi(int numOfDisc, int startPillar, int endPillar, int tempPillar) {
        if (numOfDisc > 0) {
            // shift (n-1) disc from pillar1 to pillar2 using pillar3
            solveHanoi(numOfDisc - 1, startPillar, tempPillar, endPillar);

            // shift 1 disc from pillar1 to pillar3
            int disc = pillar[startPillar].pop();
            pillar[endPillar].push(disc);

            // print the change in position of discs
            print();

            // shift (n-1) disc from pillar2 to pillar3 using pillar1
            solveHanoi(numOfDisc - 1, tempPillar, endPillar, startPillar);
        }
    }

    // print pillar1, pillar2, pillar3 respectively
    void print() {
        System.out.println("t" + stepCount + " Pillar1 " + pillar[1].toString());
        System.out.println("t" + stepCount + " Pillar2 " + pillar[2].toString());
        System.out.println("t" + stepCount + " Pillar3 " + pillar[3].toString());
        System.out.println();
        // increment the number of steps
        stepCount++;
    }
}

Related Solutions

JAVA Program a solver for the Towers of Hanoi problem presented below. Submit the Following: Hanoi.java,...
JAVA Program a solver for the Towers of Hanoi problem presented below. Submit the Following: Hanoi.java, Driver.java (contains your main method). Rules: a) There are three Pillars (Pillar1, Pillar2, Pillar3). b) There are N number of disks of increasing size (disk size is indicated by an integer). c) At the start, all disks are stacked on one of the pillars. d) At no point can a disk of larger size be placed above a disk of smaller size (including the...
Write a java program to solve Towers of Hanoi with the condition that there are "m"...
Write a java program to solve Towers of Hanoi with the condition that there are "m" number of rods and "n" number of disks. Where m >= 3 and n >=1.
Consider the following variants of the Towers of Hanoi. For each of variant, describe an algorithm...
Consider the following variants of the Towers of Hanoi. For each of variant, describe an algorithm to solve it in as few moves as possible. Prove that your algorithm is correct. Initially, all the n disks are on peg 1, and you need to move the disks to peg 2. In all the following variants, you are not allowed to put a bigger disk on top of a smaller disk. Consider the disappearing Tower of Hanoi puzzle where the largest...
Answer the following questions and upload to Canvas. Submit in Word or PDF format.  Show your work...
Answer the following questions and upload to Canvas. Submit in Word or PDF format.  Show your work and upload the Excel sheet as well. All the writing parts must be your original writing, don't quote, write in your own words. The following table presents the orders of Samson Company for the last 36 months (3 years). Month Order Year 1 Order Year 2 Order Year 3 January 502 614 712 February 408 592 698 March 491 584 686 April 456 532...
Write a program that does the following:  Assume the canvas size of 500X500.  The...
Write a program that does the following:  Assume the canvas size of 500X500.  The program asks the user to enter a 3 digit number.  The program then checks the value of the first and last digit of the number.  If the first and last digits are even, it makes the background green and displays the three digit number at the mouse pointer.  If the two digits are odd, it makes the background red and displays...
Write a program that does the following:  Assume the canvas size of 500X500.  The...
Write a program that does the following:  Assume the canvas size of 500X500.  The program asks the user to enter a 3 digit number.  The program then checks the value of the first and last digit of the number.  If the first and last digits are even, it makes the background green and displays the three digit number at the mouse pointer.  If the two digits are odd, it makes the background red and displays...
Problem:  Using Solver, solve the linear program to find the optimal number of batches to make of...
Problem:  Using Solver, solve the linear program to find the optimal number of batches to make of each of the three cookies. Price per chocolate chip cookie $                      1.50 Price per sugar cookie $                      1.00 Price per snickerdoodle cookie $                      1.00 Recipes for one batch Number of cookies/batch 20 20 30 Ingredient Chocolate chip cookie recipe Sugar cookie recipe Snickdoodle recipe Butter (sticks) 2 2 2 Sugar (cups) 1 2 1 Eggs 2 3 1 Chocolate chips (cups) 1 0 0...
Partial of the Solver Sensitivity Report for the LP model in Problem (3) is provided below....
Partial of the Solver Sensitivity Report for the LP model in Problem (3) is provided below. Microsoft Excel 16.0 Sensitivity Report Constraints Final Shadow Constraint Allowable Allowable Cell Name Value Price R.H. Side Increase Decrease $I$9 Component A 4000 11.33 4000 1250 4000 $I$10 Component B 2667 0 3500 1E+30 833 Answer the following questions based this report. (a) If 1,000 additional units of component A are available at a unit cost of $10, should the company take it? Why...
Can you provide solution in the Excel using Solver for the below problem ? On Monday...
Can you provide solution in the Excel using Solver for the below problem ? On Monday morning, you have $3000 in cash on hand. For the next seven days, the following cash requirements must be met: Monday, $5000; Tuesday, $6000; Wednesday, $9000; Thursday, $2000; Friday, $7000; Saturday, $2000; Sunday, $3000. At the beginning of each day, you must decide how much money (if any) to withdraw from the bank. It costs $10 to make a withdrawal of any size. You...
In this problem, you can use the Matlab program posted on course website and Canvas (also...
In this problem, you can use the Matlab program posted on course website and Canvas (also given in the lecture) that computes the interpolation polynomial. We want to see how well a given function can be approximated by the interpolation polynomials. Let f be a function. We divide the the interval [−0.6,0.6] into subintervals of the same length h = 0.02. The gridpoints are −0.6 = x1 < x2 < ... < x61 = 0.6. Take N = 61 points...
ADVERTISEMENT
ADVERTISEMENT
ADVERTISEMENT