Academic Integrity: tutoring, explanations, and feedback — we don’t complete graded work or submit on a student’s behalf.

Use C++ Create a simple two-dimensional predator-prey simulation. In this simula

ID: 3599810 • Letter: U

Question

Use C++

Create a simple two-dimensional predator-prey simulation. In this simulation the prey are ants and the predators are doodlebugs. These critters live in a world composed of a 20×20 grid of cells. Only one critter may occupy a cell at a time. The grid is enclosed, so a critter is not allowed to move off the edges of the world. Time is simulated in time steps. Each critter performs some action every time step. Doodlebugs eat Ants.

The ants behave according to the following model:

Move. Every time step, randomly try to move up, down, left, or right. (hints: you can use a random number generator to generate integer from 1 to 4, 1 = right, 2 = down, 3 = left, and 4 = up). If the neighboring cell in the selected direction is occupied or would move
the ant off the grid, then the ant stays in the current cell.

Breed. If an ant survives for three time steps, then at the end of the time step (that is;
after moving) the ant will breed. This is simulated by creating a new ant in an adjacent (up, down, left, or right) cell that is empty. If there is no empty cell available, then no breeding occurs. Once an offspring is produced, an ant cannot produce an offspring until three more time steps have elapsed.

The doodlebugs behave according to the following model:

Move. Every time step, if there is an adjacent ant (up, down, left, or right), then the
doodlebug will move to that cell and eat the ant. Otherwise, the doodlebug moves
according to the same rules as the ant. Note that a doodlebug cannot eat other
doodlebugs.

Breed. If a doodlebug survives for eight time steps, then at the end of the time step it will spawn off a new doodlebug in the same manner as the ant.

Starve. If a doodlebug has not eaten an ant within the last three time steps, then at the
end of the third time step it will starve and die. The doodlebug should then be removed
from the grid of cells. During one turn, all the doodlebugs should move before the ants
do.

Write a program to implement this simulation and draw the world using ASCII characters of “A” for an ant, “D” for a doodlebug and “.” A dot represent an empty location. This is an example for
10 x 10 world (we want 20 x 20).
....D....A
...A......
A.DA....A.
.....A...A
.D...D..AD

Create a class named Organism that encapsulates basic data common to both ants and doodlebugs. This class should have a virtual function named move that is defined in the derived classes of Ant and Doodlebug. You may need additional data structures to keep track of which critters have moved.

Initialize the world with 5 doodlebugs and 100 ants. After each time step, prompt the user to press Enter to move to the next time step. You should see a cyclical pattern between the population of predators and prey, although random perturbations may lead to the elimination of one or both species. (Can you think of a way to show the population of predators and prey over
time?)

Explanation / Answer

#include #include #include using namespace std; int a[20][20],p=0,q=0; void step(int g,int h,int i,int &u,int &v); class org { public : int x,y,life; }; class bug:public org { public: void birth(int e,int f) { x=e; y=f; life=0; a[e][f]=2; p++; } void move(); void breed(); void death() { a[x][y]=0; } }bugs[400]; void bug::move() { int k=0,t1,t2,i; life++; for(i=0;i0) { if(k!=1) k=(rand()%k+1); for(i=0;i0;i++) { step(x,y,i,t1,t2); if(a[t1][t2]==0) k--; } a[x][y]=0; a[t1][t2]=2; x=t1; y=t2; if(life>=3) { this->breed(); life=0; } } } void bug::breed() { int i,k=0,t1,t2; for(i=0;ix=t1; this->y=t2; } if(steps>=8) this->breed(); if(lifedeath(); } void dood::breed() { int i,k=0,t1,t2; for(i=0;i0) { if(k!=1) k=(rand()%k+1); for(i=0;i0;i++) { step(x,y,i,t1,t2); if(a[t1][t2]==0) k--; } doodle[q].birth(t1,t2); } } void display() { int i,j; char c; system("cls"); for(i=0;i
Hire Me For All Your Tutoring Needs
Integrity-first tutoring: clear explanations, guidance, and feedback.
Drop an Email at
drjack9650@gmail.com
Chat Now And Get Quote