forked from makersacademy/intro-to-python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path038_dict_operations.py
82 lines (60 loc) · 2.37 KB
/
038_dict_operations.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
# Video alternative: https://vimeo.com/954334322/c5a36d4407#t=726
from lib.helpers import check_that_these_are_equal
# Here's a great use for dictionaries: counting!
# For example, counting how many times each letter appears
# in a string.
# We can use a for loop to iterate over some items, and then
# use a dictionary to keep count of the items we've seen.
# In the process, you'll see a few dictionary functions at
# work, plus the sneaky addition of looping over characters
# in strings.
text = "the quick brush jumped over the lazy crab"
# We'll use a dictionary to keep count of the letters we've
# seen. We'll start with an empty dictionary:
letter_counts = {}
# The keys will be the letters, and the values will be the
# number of that letter we've seen.
# We'll use a for loop to iterate over each letter in the
# string:
for letter in text:
# We'll check if the letter is already in our dictionary
# of counts. We can do this using the `not in` operator.
if letter not in letter_counts:
# If it isn't, we'll add it to the dictionary with a
# starting count of 1.
letter_counts[letter] = 1
# Note that the syntax for assigning a value to a key in
# a dict is similar to assigning a variable.
else:
# If it is, we'll increment the count for that letter.
letter_counts[letter] = letter_counts[letter] + 1
# Let's print out the dictionary to see what we've got:
print(letter_counts)
# If you're curious as to why we need to check if the letter
# is in the dictionary, try uncommenting this code and see
# what happens:
# letter_counts = {}
# for letter in text:
# letter_counts[letter] = letter_counts[letter] + 1
# In the assignment above, our right hand expression tries
# to access the value for a key that has not been added yet.
# This causes an error.
# @TASK: Complete this exercise.
print("")
print("Function: count_words_by_length")
# Write this function that counts the number of words by
# how many letters they have. For example:
# words: ["hat", "cat", "I", "bird"]
# result: {3: 2, 1: 1, 4: 1}
# Since there are two words of length 3, etc.
def count_words_by_length(words):
pass
check_that_these_are_equal(
count_words_by_length(["hat", "cat", "I", "bird"]),
{3: 2, 1: 1, 4: 1}
)
check_that_these_are_equal(
count_words_by_length(["four", "four", "four", "one"]),
{4: 3, 3: 1}
)
# Once you're done, move on to 039_challenge_1_example.py