Write a program that create a

Assignment Help C/C++ Programming
Reference no: EM13852853

Design and implement a C++ program for the given specification.

Write a program that allows a user (player) to navigate a robot through a maze from the start position at the bottom left of the maze, to the centre of the maze.

The maze is constructed on a grid of 17 x 17 small squares. The maze given for this assignment is shown below, with row and column numbers. The robot starts in the bottom left corner (row 15, column 1). The robot must move vertically and horizontally along the black squares, until it reaches the square in the middle of the maze (row 8, column 8).

The row and column number system has been chosen to suit the drawing of the maze on the screen, from a two-dimensional array in the program.

The maze can be drawn from a console program using graphics characters, as shown above. A white square is ASCII character code 219, and a black square is a space character. The robot position is shown by R. The end position is shown by E. (On the computer screen, the "squares" appear as rectangles because the screen characters each occupy a rectangular shape.) If your own computer cannot display the graphics character (because you are using a different language from English, or using the Macintosh) then use the * character instead of the graphics character for a "white square".

The player can enter the commands U, R, D or L to move the robot up, right, down, or left to an adjacent black square. Also, the user can enter Q to quit the program. The program must ensure the robot stays in the black squares. If a player command would cause the robot to go to a white square, the robot must not move. Diagonal moves are not possible.

After each input, the program should display the maze image again, showing the new robot position graphically and as row and column coordinates (see the screen image above).

NOTE: The maze in the image on page 1 was used in a Micromouse competition where a robot is required to move to the middle of the maze, even though it does not know the maze layout. The robot has sensors that detect the presence of walls. The maze is designed so a robot cannot get to the middle by always staying next to either the left wall or the right wall as it moves through the maze.

For this assignment, the Micromouse maze has been modified so it requires at least one of each command (U, R, D, L) for the player to get the middle of the maze. Due to the limitations of using block graphics, the maze obstacles are solid blocks instead of walls. Also, the centre of the maze is a single square as this improves the suitability of the maze as a test for your program.

The maze layout is stored in the two-dimensional maze array given below. The row and column numbers given in the diagram on page 2 and on the screen image above are the same as the row and column numbers in the array. C++ code for the array definition is available with the assignment on AUTonline, in file Maze.cpp. Copy and paste this into your file.

Each number in the array represents the contents of the corresponding square in the maze.

- 1 means the square is blocked. This will show as a white square in the maze image.

- 0 means the square is not blocked so the robot can move to this square. This square will be black in the maze image.

The robot starts at row 15, column 1 and the user must move the robot to the square at the centre of the maze (row 8, column 8).

Attachment:- Assignment.rar

Reference no: EM13852853

Questions Cloud

How many liters of water should you add : If you have 60% alcohol and wish to dilute with water to make 12 liters 40% alcohol, How many liters of water should you add?
Why inflation is a concern to investor : What are the differences between top-down and bottom-up approaches in asset allocation. Why inflation is a concern to investor when investing in a country
Complete the accounting cycle including recording process : Complete the accounting cycle including the recording process from source documents to the post-closing trial balance for a service business. Interpret and apply generally accepted accounting principles (GAAP) to analyze, record, and report financ..
List four methods for obtaining customer feedback : List four methods for obtaining customer feedback. Name three ways you can maintain good relations with existing customers. What is the benefit of using an even number of response options in a survey question?
Write a program that create a : Write a program that allows a user to navigate a robot through a maze from the start position at the bottom left of the maze, to the centre of the maze.
Analyze the implications of the state decision : Identify a state that has not elected to participate in the Medicaid expansion initiative under the Affordable Care Act. Critically analyze the implications of the state's decision to opt out of Medicaid expansion on the citizens of the state
Characteristics of the socio-economic environment : 1. What are the characteristics of the socio-economic environment in many western European countries that reduced the negative human impact of the most recent global economic meltdown (2008)?
Draw a time line of the cash flows : Draw a time line of the cash flows. For this section of the project, students should follow and use the Cash Flow Estimation Excel Template File provided under the "Example Files for Term Project" folder.
Identify contemporary management challenges : Identify contemporary management challenges facing health care organizations. Assess the implications of various health care management challenges and methods of managing them

Reviews

Write a Review

C/C++ Programming Questions & Answers

  Explain the two different uses of the keyword virtual

Explain the two different uses of The keyword virtual

  Implement the program and find the item

This would be a function called into program. Struggling with the search aspect. Any clarification is greatly appreciated. File is 'inventory.dat'

  Program that will ask for a month

Write a program that will ask for a month (1-12) and a year (yyyy). the program should then produce a calendar showing the month name and year and have all of the days displayed under it.

  Display the complete fibonacci sequence

Display the complete Fibonacci sequence until u reach a value less than or equal one million - display the count of how many numbers are in that sequence between 1 and 1000000

  Calculate the plane coefficients

Calculate the plane coefficients (A,B,C and D)  of 3 points in a plane defined by P1, P2 and P3, and determine if the point P4 is behind or in front of the polygon surface contained within that plane.

  Reverse the order of the characters in the string

Write a program which will perform the following " using MARS - Assembly language"

  What is the current size of q

Suppose an initially-empty queue Q has performed a total of 32 enqueue operations, 10 front operations, and 15 dequeue operations, 5 of which generated QueueEmptyExceptions, which were caught and ignored. What is the current size of Q?

  Write program to input series of hourly temperatures

Create and write a c++ program which inputs series of 24 hourly temperatures from file, and outputs bar chart (using stars) of temperatures for the day.

  Display a year-by-year depreciation schedule

Create GUI screen interface that accepts input and shows output and resize the GUI screen & the list box to best fit the output displayed

  Use the getint and getintwithinrange methods

Use the getInt and getIntWithinRange methods to validate that each score ranges from 1 through 100 and add code that discards any extra entries at the prompt that asks if you want to enter another score to the application below.

  Object oriented programming paradigm is better choice

Explain why object oriented programming paradigm is considered better choice than structured programming paradigm. Does it reflect our "natural" way of thinking or do you find it artificial?

  How many generations do you want to wait

How many generations do you want to wait? How many jackalopes do you have?

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