Welcome to the Treehouse Community

Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.

Start your free trial

Python Object-Oriented Python Dice Roller RPG Roller

nicole lumpkin
PLUS
nicole lumpkin
Courses Plus Student 5,328 Points

What do you think about my code?

I really struggled with this one and used previous Community posts to see some example code. I was able to work my way through another student's code, then took a day off, then this is what I came up with without referring back to other posts. My code passed, but I'm concerned my solution is weird lol. Would anyone weigh in!?

class Hand(list):
    def __init__(self, num=0, die_class = D20):
        self.num = num
        super().__init__()

        for _ in range(num):
            self.append(die_class())

    @property
    def total(self):
        return sum(self)

    @classmethod
    def roll(cls, num):
        return cls(num)

2 Answers

Steven Parker
Steven Parker
231,533 Points

Remember, the instructions said, "I don't care how you do it, I only care that it works." :wink:

I've seen many questions on this specific challenge, and all sorts of different solutions. But generally there's two categories of solution approaches: override __init__ and have a minimal roll (such as what you did), or put all the new code into roll. Correctly done, both pass the challenge, and are equally good solutions.

But if you wanted a little extra practice, you could try solving it the other way.

nicole lumpkin
nicole lumpkin
Courses Plus Student 5,328 Points

Thank you Steven, that was just what I was trying to ask!!

nicole lumpkin
PLUS
nicole lumpkin
Courses Plus Student 5,328 Points

Here's my alternate solution(which passed)!! Thanks for challenging me to try!

from dice import D20

class Hand(list):
    def __init__(self, res):
        super().__init__()

        self.extend(res)

    @property
    def total(self):
        return sum(self)

    @classmethod
    def roll(cls, num, die_class = D20):
        res = []
        for _ in range(num):
            res.append(die_class())
        return cls(res)

QUESTION: I wrote another version, one in which if a Hand object were created outside of a class method...

hand = Hand()

...the instantiation of said Hand object would NOT require a res argument(unlike the code above). It seems to work in my IDE but is failing to pass. The reason given was 'Didn't get correct value for hand.total'. Would anyone mind playing around with the code below to see why this is happening!?

class Hand(list):
    def __init__(self, res = None):
        super().__init__()

        try:
            self.extend(res)

        except TypeError:
            self = []

    @property
    def total(self):
        return sum(self)

    @classmethod
    def roll(cls, num, die_class = D20):
        res = []
        for _ in range(num):
            res.append(die_class())
        return cls(res)    

Here is me playing around with it and it seems to work.

hand = Hand()

hand.total
Out[198]: 0

hand.extend([1,2,3])

hand.total
Out[200]: 6
Steven Parker
Steven Parker
231,533 Points

You've certainly gotten a lot of good extra practice from this challenge! :+1: