Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

C22 Phoenix - Jenny M. #42

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open

Conversation

jennymassari
Copy link

No description provided.

Copy link

@apradoada apradoada left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

GREEN!

Great job, Jenny! Overall your code passes all the tests and it works well! I left a few comments for you, but they are simply suggestions or things to think about in the future! You are more than welcome to make any changes that you would like, but they are not required! If you do make changes, feel free to let me know and I'm more than happy to take a second look!

As usual, if you have any questions about anything I've written, don't hesitate to reach out!

def draw_letters():
pass

copy_pool = {key: value for key, value in ORIGINAL_POOL.items()}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a really great dictionary comprehension, Jenny!

@@ -1,11 +1,123 @@
import random

ORIGINAL_POOL = {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great creation of a global variable!

Comment on lines +40 to +41
keys = copy_pool.keys()
key = list(keys)[index]

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Overall this works, and I get the inclination to separate out each part so you can see each step. As you get more comfortable with programming, feel free to combine these two lines into one as it is often more used in industry!
For example:

 key = list(copy_pool.keys())[index]

One other thing to note is that the .keys () is being run for each iteration of the for loop, but it's being created and used the same way each time. The same thing is happening on line 39. In order to keep the computer from having to redo the creation, it might be best to create a variable to hold that list outside the loop so that it is only created once!

if copy_pool[key] > 0:
pool.append(key)
copy_pool[key] = - 1
return pool

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The last consideration we have for this function is that it currently doesn't take the distribution of letters into account. Right now, every letter has an equal chance of being chosen. In reality, we have different amounts of each letter, so we would have a higher chance of picking something like an E over a Q! This wasn't tested, nor was it required, so you don't have to update your code to meet that, but if you'd like to extend your learning, that would be a great place to start!


def uses_available_letters(word, letter_bank):
pass
word = word.upper()
letter_bank = [letter.upper() for letter in letter_bank]

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Once again, a really great list comprehension! One small thing I would say is that you are copying over letter bank into a list of the same name. Just to avoid confusion, I would suggest using a name like letter_bank_copy.

letter_bank.remove(letter)
else:
return False
return True

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The rest of this function looks great! Well done, Jenny!


def score_word(word):
pass
score_chart = [

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A couple of notes about this particular structure!

  • This list seems like it might work better as a global variable! Especially if we were to extend this project.
  • The more nested our structure becomes, the more complicated it is to parse through. I'll comment a little more below, but even though it is a little annoying to type out, having a single dictionary where each letter maps to its point value is going to be one of the best ways to approach the scores!

All that being said, I hope this helped you understand nested data structures as it can be a very useful skill!

Comment on lines +93 to +96
for letter in word.upper():
for item in score_chart:
if letter in item["letters"]:
total += item["point"]

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is what I was talking about in terms of your score structure. When we factor in the fact that if letter in item["letters"]: runs using a loop, we end up with a triply nested loop, which is not ideal. If you changed up the structure to be a single dictionary, this exact same thing could be accomplished with a single loop!

Keep in mind that the strength of a dictionary is the fact that lookup is fast and easy. The more structures we nest inside the dictionary, the more we disrupt that fast and easy lookup!

selected_word = word

return (selected_word, highest_score)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This function looks great! Great job avoiding unnecessary extra dictionaries and lists and jumping straight to the logic of the highest scores and words! One small thing is that when you return multiple values from a function, they are returned as a tuple, so we don't need to include parentheses to indicate a tuple in the return statement.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants