Build a small card game called SWITCH using expendable array and linked list.
Basic Procedures
You must:
- Fill out a readme.txt file with your information (goes in your user folder, an example readme.txt file is provided)
- Have a style (indentation, good variable names, etc.)
- Comment your code well in JavaDoc style (no need to overdo it, just do it well)
- Have code that compiles with the command: javac *.java in your user directory
- Have code that runs with the command: java PlaySwitch
You may:
- Add additional methods and variables, however these methods must be private
You may NOT:
- Delete/change any code in your starter package such as changing class names, etc.
- Make your program part of a package
- Add additional public methods or variables
- Use any built-in Java Collections Framework classes anywhere in your program (e.g. no ArrayList,
LinkedList, HashSet, etc.)
- Use any arrays anywhere in your program (except in the Hand class data field)
- Alter any method signatures defined in this document of the template code
- Add any additional libraries/packages which require downloading from the internet
Setup
- Download the project1.zip and unzip it. This will create a folder section-yourGMUUserName-p1
- Replace "section" with z001, z002, k003, and z004 for the 4 sections respectively.
- Rename the folder replacing yourGMUUserNamewith the first part of your GMU email address/netID.
Example: k003-jkrishn2-p1
- Complete the readme.txt file (an example file is included: exampleReadmeFile.txt)
Topics Covered
Generics, Array Lists, and Linked Lists
Step 0: Overview
You are going to build a small card game called SWITCH using expendable array and linked list. You will be given two abstract classes - Card and Board, from which you will implement the game specific classes - CardSwitchand BoardSwitch. You will also implement an array list-like data structure that keeps track of the cards in a player's hand. This is the Hand class, used to represent a Player and a Deck. The Board class maintains a linked list-like data structure that keeps track of all players in the game and decides the winner of the game.
Step 1: JavaDocs
You are required to complete the JavaDoc comments for ALL classes including the ones you did not implement (except for PlaySwitch). As part of understanding this project, start with writing JavaDoc comments for the classes that are implemented for you: Card, Deck, and Board. Yes, you will be graded on this, and yes, you need to add comments to the methods and instance variables.
Step 2: Implementing and Understanding the Code
There is a total of 7 classes in the project. However, you are only required to implement some of them.
See the project starter package for all the files.
The abstract Card Class (see Card.java)
[code provided: should not be modified except for adding JavaDoc comments]
A card consists of rank and suit. A regular deck of 52 cards contains 13 different ranks and 4 different
suits. Ranks consist of ACE, TWO, THREE, FOUR, FIVE, SIX, SEVEN, EIGHT, NINE, TEN, JACK, QUEEN, and KING. Suits consist of HEARTS, CLUBS, DIAMONDS, and SPADES. In our design, every card has a point and a priority which should be implemented in its inherited
classes.
The CardSwitchClass (see CardSwitch.java)
Write a class specific to the game SWITCH by extending the abstract class Card. Required methods:
publicCardSwitch(Rank rank, Suit suit)
- Create a card with a given rank and suit
publicintgetPoints()
- Returns an integer according to the point of this card. ACE = 1 point, 2 = 2 points, 3 = 3 points, .
. . , 9 = 9 points, (10, JACK, QUEEN, KING) = 10 points each.
publicboolean equals(Card anotherCard)
- Returns true if the card is of the same rank and suit of another Card
public String toString()
- Return a string representation of the card in the form of (Rank,Suit) with all capital letters and no space. For example: (KING,SPADES) or (EIGHT,HEARTS)
The HandClass (see Hand.java)
Hand holds an array of cards that can be expanded. You need to implement the required methods and make sure their big-O value is as required. Required methods:
public Hand()
- Create an empty hand
publicintnumCards()
- Returns the number of cards in hand
public T getCard(int index)
- Returns the card at the given index. Should throw a RuntimeExceptionfor invalid index
public void setCard(int index, T c)
- Place the given card at the given index: this will replace a card that is already at that index. Should throw a RuntimeExceptionfor invalid index
public void addCard(T c)
- Append a card to the end of the hand. Remember to expand the array if it gets full publicintindexOf(T c)
- Return the index of the given card in the hand. If the card is not present, return -1
public T removeCard(int index)
- Remove and return the card at the given index in the hand. Should throw a RuntimeExceptionfor invalid index
publicbooleanremoveCard(T card)
- Remove the first occurrence of the given card from the hand and return true if removal was successful
The PlayerClass (see Player.java)
Player is a linked list node class consisting of name, points, hand, and next player. Required methods:
public Player(String name)
- Create a player setting the player's name and initializing points, hand, and the next player public void setNext(Player p)
- Set the next player. i.e., connect the linked list node to its next public PlayergetNext()
- Get the next player. i.e., get the linked list node connected to the current publicbooleanhasNext()
- Return true if the player has a next player. i.e., if the current linked list node is connected publicintgetPoints()
- Return the player's points. Total points accumulated by a player in SWITCH game is the sum of points of all cards the player currently has in the hand.
public String getName()
- Return name of the player
publicbooleanreceiveCard(T c)
Add a card to the hand and update points accordingly. Return false if the hand already contains the card, otherwise return true. If the user already has the card in hand, do NOT add it and return false.
publicbooleanhasCard(T c)
- Return true if the given card is present in the hand publicbooleanplayCard(T card)
- Remove the given card from the hand and update points accordingly. Return false if the hand does not have the card, otherwise return true
public T playCard(int index)
- Remove and return the card at the given index in the hand. Should throw a RuntimeExceptionfor invalid index
The abstract BoardClass
[code provided: should not be modified except to add JavaDoc comments]
The board keeps track of the deck, current player, and the number of players. A board should be able to add players and maintains a circularly linked list of players. i.e. Player1 à Player2 à Player3 à Player1 for a 3-player board.
The BoardSwitchClass (see BoardSwitch.java)
Write a class specific to the game SWITCH by extending the abstract class Board. Required methods:
publicBoardSwitch(Deck deck)
- Construct a board with the given deck. Make necessary initializations for other fields of Board public PlayergetCurrentPlayer()
- Return current player
publicintgetNumPlayers()
- Return the number of players on the board
public DeckgetDeck()
- Return board's deck
publicbooleanchangeTurn()
- Change current player to the next player in the circular linked list. Return true if successful
public PlayerfindWinner()
Go through the players on the board and return the player with maximum points. Use the player's name to break the tie (lexicographical order). You can assume the names are unique. publicbooleanaddPlayer(Player p)
- Add the given player to the left of the current player. Don't forget to keep the linked list circular.
See example below:
The DeckClass (see Deck.java)
[code provided: should not be modified except for adding JavaDoc comments]
A deck consists of a Hand of cards. The Deck class should be able to add cards, shuffle them, deal the next card, and check the number of cards. You will need to perform big-O analysis to all methods listed here except for the constructor.
public Deck()
- Create a deck initializing the set of cards and the card count publicbooleanaddCard(T c)
- Returns false if the deck already has the card. Otherwise, add the card to the deck and update the card count
publicbooleanhasCard(T c)
- Returns true if the deck has the given card
public void shuffle()
- Randomly shuffles the deck
public T dealNextCard()
- Returns false if the deck has no cards. Otherwise, return the last card in the deck, remove it from
the deck and upublicbooleanisEmpty()
- Returns true if the deck is empty. Otherwise returns false
publicintcardCount()
- Returns the number of cards in the deck
public String toString()
- Returns a string consisting of the cards in the deck
The PlaySwitchClass (see PlaySwitch.java)
[code provided: should not be modified. No JavaDoc comments required]
A provided implementation of a simple game with cards. The game follows these steps:
1. Creating a full deck of 52 cards
2. Creates players and adds them to board
3. Deal all cards to users one by one (all players may not receive same number of cards)
4. Switch the first n cards between the players
5. Player with the higher total points of all cards in hand is the winner
Step 3: Big-O
Template given to you in the starter package contains instructions on the REQUIRED Big-O runtime for each method. Your methods should not have a higher Big-O. For class Deck, you are required to present Big-O run time for all methods (as comments within the code) in addition to Javadoc commenting. Again yes, you will be graded on this.
Step 4: Testing
Test cases will not be provided for this project. However, feel free to create test cases by yourselves. In addition, the main methods provided along with the template classes contain useful code to test your code.
You can use command like "java CardSwitch" to run the testing defined in main( ). You could also edit main( ) to perform additional testing. And yes, a part of your grade will be based on automatic grading using test cases that are not provided to you.pdate the car
You only need to assist on hand player and cardswitch classes