/* This is a helper class for the missionaries and cannibals problem. A node represents a state of the world; it records who is on what side, where is the boat, and the set of moves that got from the initial configuration to this state Adapted by Laura Toma, from Eric Chown. */ public class QueueNode { private int cannibals1; // cannibals on side 1, etc. private int cannibals2; private int missionaries1; private int missionaries2; private int boatside; // side boat is on private int pathcost; // cost of current path private String path; // collection of moves made to get to this state public QueueNode(int c1, int c2, int m1, int m2, int bs, int pc, String p) { cannibals1 = c1; missionaries1 = m1; boatside = bs; cannibals2 = c2; missionaries2 = m2; pathcost = pc; path = p; } public int getCannibals1() { return cannibals1;} public int getCannibals2() { return cannibals2;} public int getMissionaries1() { return missionaries1;} public int getMissionaries2() { return missionaries2;} public int getCost() { return pathcost;} public int getBoatSide() { return boatside;} public String getPath() { return path;} // useful for debugging this prints out a state public String printNode() { String outstring = "Side 1 has "+cannibals1+" cannibals and " +missionaries1+" missionaries" + "\nSide 2 has "+cannibals2+" cannibals and " +missionaries2+" missionaries" + "\nThe boat is on side "+boatside+" path cost is "+pathcost + "\n"; return outstring; } public String toString() { return printNode(); } // checks to see if everyone has made it accross public boolean isDone() { if ((cannibals2 == 3) && (missionaries2 == 3) && (boatside == 2)) return true; return false; } // returns true if and only if the node represents a legal // configuration. public boolean isLegal() { // make sure those cannibals don't eat the missionaries! if ((cannibals1 > missionaries1) && (missionaries1 > 0)) return false; if ((cannibals2 > missionaries2) && (missionaries2 > 0)) return false; // don't do magic with the numbers if (cannibals1 < 0) return false; if (cannibals2 < 0) return false; if (cannibals1 > 3) return false; if (cannibals2 > 3) return false; if (missionaries1 < 0) return false; if (missionaries2 < 0) return false; if (missionaries1 > 3) return false; if (missionaries2 > 3) return false; return true; } /* creates and returns a new states that is the results of moving * 1C from the current state */ QueueNode move1C() { int c1 = cannibals1; int c2 = cannibals2; int m1 = missionaries1; int m2 = missionaries2; QueueNode q; if (boatside ==1 ) { //move from 1 t0 2 q = new QueueNode(c1-1, c2+1,m1, m2, 2, pathcost+1, path + "move 1C from 1 to 2\n"); } else { //move form 2 to 1 q = new QueueNode(c1+1, c2-1,m1, m2, 1, pathcost+1, path + "move 1C from 2 to 1\n"); } return q; } /* creates and returns a new states that is the results of moving * 2C from the current state */ QueueNode move2C() { int c1 = cannibals1; int c2 = cannibals2; int m1 = missionaries1; int m2 = missionaries2; QueueNode q; if (boatside ==1 ) { //move from 1 t0 2 q = new QueueNode(c1-2, c2+2,m1, m2, 2, pathcost+1, path + "move 2C from 1 to 2\n"); } else { //move form 2 to 1 q = new QueueNode(c1+2, c2-2,m1, m2, 1, pathcost+1, path + "move 2C from 2 to 1\n"); } return q; } /* creates and returns a new states that is the results of moving * 1M from the current state */ QueueNode move1M() { int c1 = cannibals1; int c2 = cannibals2; int m1 = missionaries1; int m2 = missionaries2; QueueNode q; if (boatside ==1 ) { //move from 1 t0 2 q = new QueueNode(c1, c2,m1-1, m2+1, 2, pathcost+1, path + "move 1M from 1 to 2\n"); } else { //move form 2 to 1 q = new QueueNode(c1, c2,m1+1, m2-1, 1, pathcost+1, path + "move 1M from 2 to 1\n"); } return q; } /* creates and returns a new states that is the results of moving * 2M from the current state */ QueueNode move2M() { int c1 = cannibals1; int c2 = cannibals2; int m1 = missionaries1; int m2 = missionaries2; QueueNode q; if (boatside ==1 ) { //move from 1 t0 2 q = new QueueNode(c1, c2,m1-2, m2+2, 2, pathcost+1, path + "move 2M from 1 to 2\n"); } else { //move form 2 to 1 q = new QueueNode(c1, c2,m1+2, m2-2, 1, pathcost+1, path + "move 2M from 2 to 1\n"); } return q; } /* creates and returns a new state that is the result of moving 1M and 1C to the "other" side */ QueueNode move1M1C() { int c1 = cannibals1; int c2 = cannibals2; int m1 = missionaries1; int m2 = missionaries2; QueueNode q; if (boatside==1) { // move from 1 to 2 q = new QueueNode(c1-1, c2+1, m1-1, m2+1, 2, pathcost+1, path + "move 1C1M from 1 to 2\n"); } else { // move from 2 to 1 q = new QueueNode(c1+1, c2-1,m1+1, m2-1, 1, pathcost+1, path + "move 1C1M from 2 to 1\n"); } return q; } }