联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Java编程Java编程

日期:2020-12-19 11:14

Project “Amazons”

Game instruction

1. This is an extended version of board game "The Amazons"

2. The game is played on chess-like board, but the size of the board is not fixed. Moreover, there

can be treasure or some artifact on each field of the board. The game can be played by one, two

or more players. Each player has a given number of amazons.

3. The game starts with the setting phase played in turns. In a single turn the current player places

one of his amazons on an unoccupied field. Then, the next player does the same. This steps are

repeated until all amazons are placed. Players do not get treasures of artefacts during that phase,

however the treasure and artifacts are removed from the used fields.

4. Game is played in turns. In his turn the player moves one of his amazons one or more fields in a

straight line horizontally, vertically or diagonally. Then, the moved amazon shoots an arrow in

a straight line horizontally, vertically or diagonally at least at distance of one field. Neither

amazon nor the arrow can cross or enter a field with an obstacle, that is, another amazon, landed

arrow or spear.

5. When the player cannot make a valid move then his turn is skipped. Game ends when all

players have no valid move.

6. After moving the amazon, the player collects the treasure and the artifact from the field where

the amazon landed. The treasure can be worth from 1 to 5. The artifact must be used

immediately.

7. The winner is the player who gets the most treasure.

8. The artifacts are as follows:

a) a horse - the amazon immediately does the next move

b) a broken arrow - the amazon does NOT shoot an arrow after moving

c) a spear - instead of shooting an arrow, the amazon throws a spear; No obstacle blocks the

throw, so the spear can literally land on any field with no amazon or arrow and the field

becomes an obstacle, like in case of arrow. The spear can be moved only horizontally,

vertically or diagonally.

Your task

Your aim is to deliver a program that will play the game, either autonomously or interactively,

within the proposed procedure (see further in this text).

The text file format describing the state of the game

row 1 (board dimension): m n

rows 2 to m+1: n fields separated by single space, each field consists of 3 digits: first digit represents

the value of treasure (0-5), second digit represents an artifact (0-none, 1-horse, 2-broken

arrow, 3-spear), and third digit informs about occupation (0-tile is unoccupied, 1-8 ID of

the player, 9-arrow or spear). A combination of numbers 000 represents an unoccupied

field with no treasure and no artifact. In his turn the player modifies the field of departure

and field of arrival of the amazon as well the field destination of arrow (spear). If the last

digit is in the range 1-8, the first and the second digits should be 0.

row m+2 and consecutive: 3 fields separated by single spaces: first field is unique player name (string

no longer than 15 characters, without spaces, without quotation marks), second field is

player’s ID (number 1 to 8), third field shows the number of points collected so far from

treasure. If there is no row with player’s name (at the beginning of the game) player must

add a corresponding row at the end of the file, containing the name and setting consecutive

player’s number as the ID and initial points set to 0. Otherwise, the player should alter his

current score by the number of the collected points, and leave other fields unchanged.

Be aware that each line of the file may end with any number of spaces, try to prepare as much robust

program as you can.


Your program should accept command line parameters:

 phase=phase_mark – phase_mark can take value placement or movement

 amazons=N, where N is a number of amazons that player has; this parameter is only

specified if phase=placement;

 inputboardfile – name of the file that contains current game state

 outputboardfile – name of the file in which the new game state should be stored

 name – request to display player’s name end exit the program.

iputboardfile and outputboardfile can be the same file (can have the same name)

Examples:

game.exe phase=placement amazons=3 inputboard.txt outpuboard.txt

game.exe phase=movement board.txt board.txt

game.exe name

If phase=placement, then the program is supposed to read the game state from the file, place one

amazon on the board, save the game state to the output file and exit. In total, the program cannot place

more than N amazons on the board (as defined by the amazons parameter). In such a case the

program exits immediately returning appropriate error code (see later).

If phase=movement, then the program is supposed to read the game state, move one of his amazon

and shoot an arrow, alter the score, save the game state and exit. If the move is not possible, the

program should exit immediately returning appropriate error code (see later).

If parameter name is used, then other parameters are ignored. Program should display only the player’s

name hidden (written directly) in the code. This option enables the game master to identify players.

Interactive game

The program should also be ready to be compiled for an interactive mode (use preprocessor directives

to choose the mode). In the interactive mode the program should allow to play interactive game

between two players sitting in front of the computer. The game state does not have to be stored in the

output file. The game state can be presented in a text mode (graphics mode is not compulsory).

Result returned by the program

Program should end in a controlled way, returning to the operating system one of the values (specified

as the argument of the return statement in the main function):

0 - program made the correct move

1 - program can not make any move (in the placement phase - all amazons have been placed; in the

movement phase – all amazons are blocked)

2 - error of the game state in the input file; in such a case additional error message should be

displayed identifying the cause and the position of the error in the input file

3 - internal program error, possibly with additional message

Additional issues: think how you can prevent cheating by your opponent.

Gameplay

Game is managed by game master, i.e. operating system script provided by Instructor. Script generates

the board (players do not create initial board), then players’ programs are run in a loop. For example,

let program1.exe, program2.exe and program3.exe be the programs provided by students 1, 2 and

3, then the script works according to the following pseudo-code:

generate_board.exe

while(true)

kod1 = program1.exe phase=placement amazons=3 board.txt board.txt

kod2 = program2.exe phase=placement amazons=3 board.txt board.txt

kod3 = program3.exe phase=placement amazons=3 board.txt board.txt

if (kod1 == 1 && kod2 == 1 && kod3 == 1) break;

}

while(true)

kod1 = program1.exe phase=movement board.txt board.txt

kod2 = program2.exe phase=movement board.txt board.txt

kod3 = program3.exe phase=movement board.txt board.txt


if (kod1 == 1 && kod2 == 1 && kod3 == 1) break;

}

Programs compiled for an interactive mode should allow a human player (instead of the computer) to

make a decision about next placement/move.

Teamwork

Project is made in groups consisting of 3-4 persons. Group members are selected by Instructor, you are

not supposed to change the membership. Teamwork supporting tools will be utilized, including GitLab.

It is group project, so consider choosing a project manager among team members to ease the workflow.

However, each student is expected to be able to explain any part of his/her

code. Contribution of each student must be clear and reflected in the source files as well as clearly

visible at GitLab.

Git repository

To ease the team work, the use of version control system is required. Git is one of the most popular

ones. It is required that each group creates its own git repository (git project). It allows both web based

and command line based access to projects. Use faculty gitlab server: https://gitlabstud.elka.pw.edu.pl/

Assessment (max 30 points)

1. Assessment of your progress made during T1-T5 (10 points, detailed scores provided in the

schedule below)

2. Final assessment and tournament during T6 (20 points)

a) Project structuring (division of the source code into files, function breakdown) (4 points)

b) Code quality (clarity, simplicity, comments, good naming convention, formatting,

appropriate data types and data structures) (5 points)

c) Testing (automated tests, documented manual tests) (4 points)

d) General impression (5 points)

e) Tournament result (2 points)

Extremely important remark: assessment is made individually (if the program is perfect, but your

contribution is low, you will get very few points; if quality of the code is high, but your part is weak,

you will get much less points than others; if your program is not fully functional, since one team

member failed in his tasks, you still can get maximum).

To trace your activity and see your contribution we will use GIT statistics. Activities not

registered at GIT or software not added to repo will be not taken into account.

Schedules (with points)

T0. Kick-off meeting, introduction to the challenge. Start working on flowcharts to sketch the general

concept (start with an interactive mode and then extend it for autonomous mode).

Everybody needs to deliver individual flowchart (or flowcharts) one day before T1.

T1. Discussion of submitted flowcharts (max 2 points).

Establishing the teams, preliminary discussion in teams. Agree on communication channels in the team.

Organize your work (GitLab required). Put chosen flowcharts to the repository.

T2. Present preliminary code for an interactive mode: main loop, interaction with user. Show it and run

it. (max 1 point)

T3. Present the structure of the project in terms of division into files and functions. Present declarations

of each function with comments describing arguments, results and purpose of the function. Create

issues on GitLab and assign team members to issues. (2 points)

T4. Present data structures for board, printing board on the screen. The user should be able to set the

amazons, make movement, but still it can be imperfect. (2 points)

T5. Handling the files, runtime arguments processing. Your program should read and write to file

according to the specification. It should interpret properly command line arguments. (3 points)

T6. Tournament, final assessment.

Each presentation cannot be longer than 8 minutes. Everything what is to be presented and to be

assessed must be pushed to GIT before the meeting (create folders with meaningful names). If you had

team meeting, then make a note and attendance list and put it on GIT. Alternatively, usage of individual

group channel on Teams is recommended. Let every team member say few words about their

contribution during last period. The main person to present the work you did can be chosen by the

lecturer.

The aim of the presentation is to get the feedback and make sure that the project is going well. You are

expected to be an active listener - remember, that you can find answers to your concerns or brilliant

ideas in other students' projects and use it in your project.

TIPS & TRICKS

1. Always keep the source code ready to be compiled - use commenting for that

2. Assign the tasks to everybody in the team, especially from T3, when you can work in parallel.

3. Don’t start with loading/saving files. You may do a lot of things having some constants in your

program and then you can replace them with data read from file.

4. It's better to have simple solution that will work than the most sophisticated algorithm but not

working. Try to work incrementally, be agile!

Q & A (To be filled in as questions arise)

1. Q: Does the amazon shoot an arrow twice in case of "horse" artifact?

A: Yes, shooting an arrow is a part of a move. So the amazon makes move, shoots an arrow,

collects an artifact (a horse), moves and shoots an arrow once again.

2. Q: Is our program expected to do the optimal moves, so it must have a kind of artificial

intelligent in it?

A: First, you should do the program that will follow all assumptions especially regarding

command line parameters and file format, but with the simplest possible intelligence. For

instance you may make decisions randomly. Then you may master you decision algorithm. Try

to put some reasonable rules, make some improvements. However, optimal decisions and very

sophisticated algorithm is not expected. You still may do it for your satisfaction, glory and

victory in the tournament, but notice, that amount of points for the winner is almost

insignificant.


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp