You are to implement five classes. The behavior of each class is described below.

Class getChar getMove

Bird B Randomly selects one of the four directions each time

Frog F Picks a random direction, moves 3 in that direction, repeat (same as bird, but staying in a single direction longer)

Mouse M West 1, north 1, repeat (zig zag to the NW)

Turtle T South 5, west 5, north 5, east 5, repeat (clockwise box)

Wolf W You define this

For the random moves, each possible choice must be equally likely. You may use either a Random object or the Math.random() method to obtain pseudorandom values.

The first four of these classes won’t use the CritterInfo object that is passed to getMove. This object is provided in case you want to do something with this information in defining your Wolf class. See the description of CritterInfo later in the writeup.

The critter world is divided into cells that have integer coordinates, much like the pixels in a DrawingPanel. There are 100 cells across and 50 cells up and down. As with the DrawingPanel, the upper-left cell has coordinates (0, 0), increasing x values move you right and increasing y values move you down.

Notice that the Critter class defines five constants for the various directions. You can refer to these using the name of the interface (Critter.NORTH, Critter.SOUTH, etc) or you can refer to them directly (NORTH, SOUTH, etc) because you are implementing the interface. Your code should not depend upon the specific values assigned to these constants, although you may assume they will always be of type int. You will lose style points if you fail to use the named constants when appropriate. As noted above, your critter can stay in its current location by indicating that the direction it wants to move is CENTER.

Here are the five classes implemented according to the provided descriptions:

```java
import java.util.Random;

public class Bird implements Critter {
private Random rand;

public Bird() {
rand = new Random();
}

public char getChar() {
return 'B';
}

public int getMove(CritterInfo info) {
int randomDirection = rand.nextInt(4);
return randomDirection;
}
}

public class Frog implements Critter {
private Random rand;

public Frog() {
rand = new Random();
}

public char getChar() {
return 'F';
}

public int getMove(CritterInfo info) {
int randomDirection = rand.nextInt(4);
return randomDirection;
}
}

public class Mouse implements Critter {
private int x, y;
private boolean zigzag = true;

public Mouse() {
x = 0;
y = 0;
}

public char getChar() {
return 'M';
}

public int getMove(CritterInfo info) {
if (zigzag) {
if (x < 99 && y < 49) {
x++;
y++;
} else {
zigzag = false;
}
} else {
if (x > 0 && y > 0) {
x--;
y--;
} else {
zigzag = true;
}
}
return Critter.CENTER;
}
}

public class Turtle implements Critter {
private int step;

public Turtle() {
step = 0;
}

public char getChar() {
return 'T';
}

public int getMove(CritterInfo info) {
step++;
if (step % 20 == 1) {
return Critter.SOUTH;
} else if (step % 20 == 6) {
return Critter.WEST;
} else if (step % 20 == 11) {
return Critter.NORTH;
} else if (step % 20 == 16) {
return Critter.EAST;
} else {
return Critter.CENTER;
}
}
}

public class Wolf implements Critter {
public char getChar() {
return 'W';
}

public int getMove(CritterInfo info) {
// Define the behavior for the Wolf class here
// ...
}
}
```