Java application game of life, JAVA Programming

Assignment Help:

The game of Life, invented by John Conway, is supposed to model the genetic laws for birth, survival, and death (see Scienti_c American, October 1970, p. 120). We will play it on a board with a maximum of 60 squares (i.e. columns) in the horizontal direction and a maximum of 20 squares (i.e. rows) in the vertical direction. Each square can be empty or contain an X indicating the presence of an organism. The small dashed square shown in the segment of the board drawn below connects all the neighbors of the organism in row 3, column 3 (note that the upper left corner cell on the board is at location row 1, column 1).

1940_game.png

The next generation of organisms is determined according to the following criteria:

Birth An organism will be born in each empty location that has exactly three neighbors.

Death An organism with four or more organisms as neighbors will die from overcrowding. An organism with fewer than two neighbors will die from loneliness.

Survival An organism with two or three neighbors will survive to the next generation.

Generations 2 and 3 for the sample follow:

430_game1.png

Generation #2 Generation #3

2131_game2.png

Note that each new generation is computed only from the data in the previous generation. In other words, when considering a cell's neighbors you only use the information on the previous generation, not the data (organisms) in the current generation you are computing.

You should allow for a minimum game board of 3 rows by 3 columns and a maximum size of 20 rows by 60 columns. Read in an initial configuration of organisms from a text data _le

(specified on the command line with the _le name echo printed to the screen; do not make any assumptions about the name of this _le) with the following format:

1084_game3.png

 

Any data, characters, or blank lines that might follow the '0 0' sentinel value pair should be ignored.

Use the following algorithm as a starting point for writing your simulation:

initialize the board to empty (i.e. no organisms)

set generation equal to 1

input starting board from data _le

write board to screen and pause

repeat

increment generation by 1

compute the next generation

write new generation to screen and pause

until _nished

Be sure to subdivide your code into appropriate methods as discussed in class.

All inputed data must be in the ranges indicated; any erroneous data should be reported to the user and a fatal exception (of type java.lang.RuntimeException; see below) should be raised. Each board should be printed in text mode (i.e. do not use graphics and/or separate windows|you must use print, println, or printf to produce your output) and should be labeled with its generation number, with the initial con_guration labeled as generation 1.

You should number the rows and columns in the manner shown in the examples (especially note the numbering in the second sample run below) that follow plus print a boundary around each board (using the +, -, and | characters) and use the X (capital x) character to represent organisms, e.g. the Generation 1 board on the previous page would be drawn like this:

1234

+----+

1| |1

2| X X|2

3| X |3

4| X |4

5| X X|5

+----+

1234

(Note that there are no blank rows in the example given; this board is printed using 9 rows total, counting the numbering and borders.) You should also pause between printing each generation, continuing only when the user presses the ENTER key; make sure they are prompted to press enter to continue (probably the easiest way to do this is by just calling the nextLine() method in the Scanner class).

Exceptions can be raised using the following code:

if ( some_condition ) throw new java.lang.RuntimeException("your error message goes here"); where some condition is the boolean error condition you are checking for, and the string passed to the constructor for java.lang.Exception should be some appropriate error message to the user.

2 Sample Runs

The following are only partial sample runs.

2.1 Sample Run #1

Data _le life2.dat:

3

3

5

1 2

3

2 2

3 2

0 0

Sample run:

liberty:~/javaprogs/% java Life2012 life2.dat

Game of Life (with board wrap)

D. Resler 2/99 [2012]

Opened file: life2.dat

Generation 1:

123

+---+

1| X |1

2| X |2

3| X |3

+---+

123

(press enter to continue)

Generation 2:

123

+---+

1| |1

2|XXX|2

3| |3

+---+

123

(press enter to continue)

Generation 3:

123

+---+

1| X |1

2| X |2

3| X |3

+---+

123

4

(press enter to continue)

Generation 4:

123

+---+

1| |1

2|XXX|2

3| |3

+---+

123

(press enter to continue)

Generation 5:

123

+---+

1| X |1

2| X |2

3| X |3

+---+

123

(press enter to continue)

liberty:~/javaprogs/%

2.2 Sample Run #2

Data _le lifeHandout.dat:

20

60

20

6 27

6 29

7 27

7 29

8 27

8 28

8 29

0 0

Sample run:

liberty:~/javaprogs/% java Life2012 lifeHandout.dat

Game of Life (with board wrap)

D. Resler 2/99 [2012]

(press enter to continue) (More would follow { not a complete run!)

3 Deliverables

You are to turn in your project through the project submission form on the class web page. Name your source code _le Proj7XXXX.java where XXXX is the last 4 digits of your student id number (and your class should therefore be named Proj7XXXX).


Related Discussions:- Java application game of life

Linked list, i want code for to print prime numbers in the linked list queu...

i want code for to print prime numbers in the linked list queue and stack and array in java programming

Give an example of code using static and finalize, Give an example of code ...

Give an example of code using static and finalize Example Code: using static & finalize () We want to count exact number of objects in memory of a Student class the one de

What should be public and private, What should be public? What should be pr...

What should be public? What should be private? As a rule of thumb: Classes are public. Fields are private. Constructors are public. Getter and setter methods

Different types of messages available in the jms api, What are the differen...

What are the different types of messages available in the JMS API? Ans) Message, TextMessage, BytesMessage, StreamMessage, ObjectMessage, MapMessage are the dissimilar messages

Explain javamail, Normal 0 false false false EN-IN X-...

Normal 0 false false false EN-IN X-NONE X-NONE MicrosoftInternetExplorer4

Websphere - weblogic, WebSphere - Weblogic and Apache: Building/Ins...

WebSphere - Weblogic and Apache: Building/Installation  and maintenance of Solaris and Linux machines. Exposure to Sun Hardware : Sunfire v880,v890.V440,X4600

Need minecraft bukkit plugin programmer, Need Minecraft Bukkit Plugin Progr...

Need Minecraft Bukkit Plugin Programmer I want to make my own server for Minecraft. I am in need of a experts to make custom bukkit plugins for my server. But basically I will w

Describe the java.lang package, Describe the java.lang package ? Each p...

Describe the java.lang package ? Each package describes a number of classes, exceptions, interfaces, and errors. For instance, in Java 1.1 the java.lang package holds these:

What are the role of keywords in java, What are the role of Keywords in jav...

What are the role of Keywords in java? Keywords are identifiers such as public, static and class in which have a special meaning inside Java source code and outside of comments

Convert psd to android, Convert PSD to Android (UI only, no database) Pr...

Convert PSD to Android (UI only, no database) Project Description: I want someone highly proficient in Photoshop and Android SDK to change series of PSD files into live Andro

Write Your Message!

Captcha
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