Simulate a game of tic tac toe

Assignment Help JAVA Programming
Reference no: EM131589189

You must implement the classes as specified in the UML diagram. You may add other methods if needed, however, all the methods and the variables indicated in the UML diagram must be implemented. You must submit one zip file containing the source codes (.java files) and a text document with sample outputs. All your programs must be nicely formatted and commented.

Develop the code in a step-by-step manner. Each correctly developed code piece will get you points.

The objective of this assignment is to simulate a game of tic tac toe. For those of you who are not familiar with the game, you can check out the following website:

1345_Figure.png

Figure 1 below shows some sample tic toe toe boards with some input.

You will be using the concepts of inheritance and aggregation in object-oriented programming. You will also need to use 2-d arrays to represent the grid of the tic tac toe board. 2-d arrays are similar to 1-d arrays except that they use two indices. There is a small tutorial on 2-d arrays at the end of this assignment. Check it out.

There are three main classes (Board, TicTacToeBoard, XO) and one additional class called Play that will use and run the classes (that is, play the game). See the UML diagram below to see how the classes fit together.

1043_Figure1.jpg

XO Class - this class will hold information about an "X" or an "O" object.
This class should have two attributes: a name (which is a String "X" or "O") and a static int variable that is either set to 0 or 1 (it should be initialized to 1). You will use this variable to determine which name to give the object when it is created (e.g., if it is 1, set the name to "X").

You need to implement a no args constructor that sets the name of the object to either X or O based on the static variable (and update the variable). You also need to implement:
• the respective get and set methods
• an equals method to see if this XO object is the same as another XO object
• a toString method that returns the name of the XO object

Board class - this is a class used to implement a variety of different boards for different games (e.g., a chess board, checkers board, and in our case a tic tac toe board). This class has two private attributes: the number of rows and number of columns of the board.

It also has the following methods:
• It has a constructor that takes in and initializes the rows and columns
• The appropriate get/set methods
You may add other methods if required.

TicTacToeBoard
This class extends the Board class. It has two private variables:
• A 2D array made up of XO objects with the size of Boards' rows and columns
• An int that keeps track of how many turns (e.g., how many X's and O's have currently been placed on the board.)

Methods
• The constructor takes in two ints representing the rows and columns. It initializes the 2D array to the size of rows and columns, and sets count of turns to 0.
• There are appropriate get and set methods
• It also implements. the following methods:
• The add method will add a new XO object onto the board (add to the 2D array). The method takes in two numbers representing which row and column you want to add the object. It returns a boolean if the object was successfully added. It will need to make sure that the passed in rows and columns are within the size restrictions of the board. It will also need to make sure that the place on the board doesn't already have an XO object.
• The winner method checks to see if there is a winner (returns true or false). The method will need to check for wins by rows, columns and across the diagonals. See Fig. 1 for the winning combinations.
• A toString method that prints out what the current board looks like. The toString method should print out the board similar to the sample output (at the end of the assignment). And as XOs are added to the board, these should also be printed.

You may add other methods in this class (e.g., to check for the different winning combinations).

Play class
This class will allow users to play the game (e.g., the demo class). You will create a new TicTacToeBoard. You should use a Scanner object to get the names of your two players and to get the locations of their respective X and O's on the board. The game should continue until there is a winner or there is a tie (ie., no more places to put an XO). Make sure you do proper error checking. See below for a sample output of a game. Your output should show the different conditions.

Short Tutorial on 2-d arrays

2-d arrays are very similar to 1-d arrays except that they have two subscripts or indices, one representing the row number and the other representing the column number.

For example,
int[][] a = new int[5][5];

creates a 2-d array with 5 rows and 5 columns.

You can process the 2-d array in the same manner. Instead of one for loop, we use a nested for loop. For example,

for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
System.out.print(a[i][j] + "\t"); System.out.println();
}

will print the contents of the array as a 5X5 matrix.

The boxes will be numbered as follows:

 

Column 0

Column 1

Column 2

Column 3

Column 4

Row 0

a[0][0]

a[0][1]

a[0][2]

a[0][3]

a[0][4]

Row 1

a[1][0]

a[1][1]

a[1][2]

a[1][3]

a[1][4]

Row 2

a[2][0]

a[2][1]

a[2][2]

a[2][3]

a[2][4]

Row 3

a[3][0]

a[3][1]

a[3][2]

a[3][3]

a[3][4]

Row 4

a[4][0]

a[4][1]

a[4][2]

a[4][3]

a[4][4]

If you want to print all the elements in Column 2, for example:
for(i=0;i<5;i++)
System.out.println(a[i][2]);

Similarly, the following will print the elements in Row no.3
for(j=0;j<5;j++)
System.out.print(a[3][j] + "\t");
The following program creates a 2-d array, reads 25 integers from the keyboard, prints it as a 5X5 matrix and finds the sum of all elements. Note that the 25 integers can be entered all on a single line when they are read from the keyboard. Try it out.
import java.util.Scanner; public class TwoDArray
{
public static void main(String[] args)
{
int[][] a = new int[5][5]; int i,j, sum=0;
Scanner keyboard = new Scanner(System.in);

for(i=0; i<5;i++)
for (j=0;j<5; j++)
a[i][j]= keyboard.nextInt();

for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
System.out.print(a[i][j] + "\t"); System.out.println();
}

for(i=0;i<5;i++)
for(j=0;j<5;j++)
sum+=a[i][j];
System.out.println("The sum of all elements is: " + sum);
}

}

Array initializer expression for 2-d arrays

A 2-d array can be created using an array initializer expression. For example:

int[][] numbers = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
creates the following array
1 2 3 4
5 6 7 8
9 10 11 12

Length field in a 2-d array
A 2-d array has a length field that holds the number of rows, and each row has a length field that holds the number of columns.

The following program uses the length fields of a 2d array to display the number of rows, and the number of columns in each row. Try it out.

public class Lengths
{
public static void main(String[] args)
{
int[][] numbers = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
System.out.println("The number of rows is " + numbers.length); for(int index=0; index<numbers.length; index++)
System.out.println("The number of columns in row " + index + " is " + numbers[index].length);
}
}

Reference no: EM131589189

Questions Cloud

Concepts of absolute and comparative advantage : Explain to someone with no economic knowledge the concepts of Absolute and Comparative Advantage and why each makes a valid argument for international trade.
Implement the interface map : Define the interface Map. A class that realizes Map has to save the key-value association. In our case, we need a Map to contain identical keys
Absence of additional income or health services : What measures can families take, even in the absence of additional income or health services, to keep their children healthy? Explain
What is the slope of the budget constraint : Draw Marie's budget constraint with pies on the horizontal axis and magazines on the vertical axis. What is the slope of the budget constraint?
Simulate a game of tic tac toe : Classes as specified in the UML diagram. You may add other methods if needed, however, all the methods and the variables indicated in the UML diagram
Prepare a consolidated worksheet for brooks and chandler : Show how Brooks determined the following account balances Gain on bargain purchase. Prepare a December 31, 2015, consolidated worksheet for Brooks and Chandler
Analyze effectiveness of burberrys mobile marketing campaign : Analyze the effectiveness of Burberry's mobile marketing campaigns by applying relevant branding and promotion concepts.
How price elastic or inelastic are they : Is tap water price elastic or inelastic? Is corn price elastic or inelastic? How price elastic or inelastic are they?
Larger budget deficit cause a trade deficit : 1. What are some of the ways fiscal policy might encourage economic growth? 2. Under what conditions will a larger budget deficit cause a trade deficit?

Reviews

Write a Review

JAVA Programming Questions & Answers

  What is an illustration of a javascriptreg framework in the

what is an example of a javascriptreg framework? in the framework you have described what is an example of an

  Determine the decision of java

Determine the decision of Java as the platform to develop this program. Identify the Java-based technologies utilized in this project and analyze each of them. Then, provide discussion on the purpose of each of the Java-based technologies utiliz..

  Create two separate java codes resulting in the same output

I need to create two separate Java codes resulting in the same output (one using Apache Commons library and one using the standard Java methods). The program should count all people with the same last name and then change the last name to Doe.

  Provide java code for a method

Provide Java code for a method that would perform functionality of your choice. Try to create functionality that is unique - something that you could use. Be sure to include an example call to your method and explain the code you developed.

  Write a function that searches a [n][n] matrix

there is a y or multiple y values with a blank on one side (left/right or top bottom) and a x on the other

  Write a java program

To become familiar with how infix expressions can be converted to postfix expressions.

  Preexisting arrays and functions

You are given a java file HW2.java with preexisting arrays and functions. Do not modify the main function or other functions names .Each function are given a certain implementation which you need to complete.

  Write program that uses a linkedlist object to store a list

Write a program that uses a LinkedList object to store list of print jobs in FIFO queue. Write program that uses one of Map classes to implement a contact list.

  Code 2-dimensional array that stores the average scores

Instructions: Code a 2-dimensional (2D) array that stores the average scores for 2 football teams across 2 years. In a method called setAvgScores, prompt for the averages and store them in the 2D array which will be returned

  Create a class called scorelist according to the uml diagram

Create a class called ScoreList according to the UML diagram. This class will allow a user to enter up to 100 scores into an array.

  Write a short, structured design that accomplishes this task

Identify how you can encapsulate the data and processes you identified into an object oriented design.

  Prints all real solutions to the quadratic equation

Write a Java program that prints all real solutions to the quadratic equation ax^2 + bx + c = 0. Read in a, b, c and use the quadratic formula

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd