n the code template below, you are given three classes

Microsoft Visual C#
7th Edition
ISBN:9781337102100
Author:Joyce, Farrell.
Publisher:Joyce, Farrell.
Chapter10: Introduction To Inheritance
Section: Chapter Questions
Problem 2CP
icon
Related questions
Question

In the code template below, you are given three classes: CardCardSet, and Deck.

The Card class has the attributes of value and suite, which describe the cards in a standard 52-card deck. The attribute value takes in the digits 1 to 10 as well as the standard face cards, Jack, Queen, and King. The suite attribute takes in the four suites, namely clubsspadeshearts, and diamonds. Obviously, two cards are equal if they have the same value and suite.

The CardSet class is just an ensemble of Card instances. To know which cards are in your set, just iterate through the cards via the view method. This gets a formatted list of your cards in the cards attribute. To add cards to your set, use the add_cards method.

The Deck class is a child class of the CardSet class. To initialize a deck, all 52 cards from the standard deck must be added to it. For uniformity, place each suite in ascending value -- 1 to 10, then Jack, then Queen, then King. The suites must be placed in this order: clubs - spades - hearts - diamonds. Note that all the diamond-suited cards are at the top of the deck, while the clubs are at the bottom of the deck. To visualize:

cards_in_deck=["1 of clubs","2 of clubs",..."King of clubs","1 of spades","2 of spades",..."King of spades","1 of hearts","2 of hearts",..."King of hearts","1 of diamonds","2 of diamonds",..."King of diamonds"]

The cards inside a deck may also be shuffled. A seed argument is added for reproducibility. The peek method of the class allow you to peek at the top n cards. The default value for n is 5.

Lastly, The draw method allows you to draw the top n cards of the deck and transfer these cards to a CardSet instance. The default value of n is 5. Note that the number of cards that you can draw cannot exceed the current number of cards in the deck.

In this exercise, you will simulate drawing two sets, each with n cards from a shuffled deck.

Input Format

The first line contains a comma-seperated string containing the integer seed, which is the seed for reproducibility, hand, the number of cards to draw per card set, and peek, the number of cards to peek at the top of the deck. The input follows this format:

<seed>,<hand>,<peek>

Constraints

None

Output Format

See sample outputs

Sample Input 0

17,2,4

Sample Output 0

Round 1: Hand A: 8 of hearts 1 of hearts Hand B: 7 of spades Jack of spades Cards Left: 48 4 Cards at the top: 6 of spades Queen of clubs 7 of diamonds 9 of hearts Round 2: Hand A: 8 of hearts 1 of hearts 6 of spades Queen of clubs Hand B: 7 of spades Jack of spades 7 of diamonds 9 of hearts Cards Left: 44

USE THIS TEMPLATE AND PLEASE DON'T COPY CODES FROM OTHER SITES BECAUSE THEY ARE WRONG!!!

import random

class Card:
    def __init__(self, value, suite):
        self.value = value
        self.suite = suite

    def __str__(self):
        return f"{self.value} of {self.suite}"

    def __eq__(self, other):
        """Check if two cards are the same"""
        # -- YOUR CODE HERE --

class CardSet:
    def __init__(self):
        self.cards = []

    def view(self):
        for card in self.cards:
            print(card)

    def add_cards(self, cards):
        """Add cards to your set"""
        # -- YOUR CODE HERE --


class Deck(CardSet):
    def __init__(self):
        """Initialize the 52-card set. Start from 1-11, then Jack, Queen, King, then by suite: clubs, spades, hearts, diamonds"""
        cards = []
        # -- YOUR CODE HERE --
        self.cards = cards
        
    def count_cards(self):
        """"Count the number of cards in a deck"""
        # -- YOUR CODE HERE --

    def shuffle(self, seed=None):
        """Shuffle your deck using a random seed"""
        random.seed(seed)
        # -- YOUR CODE HERE --

    def peek(self, number=5):
        """Show the top n cards of the stack. This is analogous to getting the last n cards then reversing it."""
        # -- YOUR CODE HERE --

    def draw(self, cardset, number=5):
        """Transfer the top n cards of the stack to your cardset."""
        # -- YOUR CODE HERE --

    def add_cards(self):
        pass

if __name__ == "__main__":
    seed, hand, peek = input().split(",")

    myDeck = Deck()
    handA = CardSet()
    handB = CardSet()

    myDeck.shuffle(int(seed))

    for x in range(1,3):
        print(f"\nRound {x}:")

        myDeck.draw(handA, int(hand))
        myDeck.draw(handB, int(hand))

        print("Hand A: ")
        handA.view()
        print("Hand B: ")
        handB.view()

        myDeck.count_cards()
        if(x == 1):
            print(f"\n{peek} Cards at the top: ")
            myDeck.peek(int(peek))
 

Expert Solution
steps

Step by step

Solved in 2 steps

Blurred answer
Knowledge Booster
Reference Types in Function
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
  • SEE MORE QUESTIONS
Recommended textbooks for you
Microsoft Visual C#
Microsoft Visual C#
Computer Science
ISBN:
9781337102100
Author:
Joyce, Farrell.
Publisher:
Cengage Learning,
C++ Programming: From Problem Analysis to Program…
C++ Programming: From Problem Analysis to Program…
Computer Science
ISBN:
9781337102087
Author:
D. S. Malik
Publisher:
Cengage Learning