IMPORTANT: For Quiz 03, focus on the problems with dictionaries!
These questions are meant to test your understanding from Lists, Dictionaries, for Loops. You should complete those before doing the questions below.
Questions
- The following questions will refer to the list below:
list[int] = list() my_list:
- 1a. Write line(s) of code that would add the number
8
,0
,3
, and-1
to the list. - 1b. Write line(s) of code that removes
3
from the list. - 1c. Write line(s) of code that assigns the variable
dog
to the element at the second index. - 1d. Write line(s) of code that prints the amount of items in the list.
- 1e. Change the value
8
to0
. - 1f. We now have a function,
sum
that adds the elements of my_list and returns this amount. Write a line of code that instantiates alist[int]
with the first value returned from callingsum
onmy_list
.
- The following questions will refer to the dictionary below:
dict[int, str] = {} my_dict:
- 2a. Write line(s) of code that would add the following key-value pairs to the dictionary:
8: 'eight'
0: 'zero'
3: 'three'
-1: 'negative one'
- 2b. Write line(s) of code that removes value
three
. - 2c. Write line(s) of code that assign the value associated with the key
0
inmy_dict
to a variable calledcat
. - 2d. Write line(s) of code that print the number of keys in
my_dict
. - 2e. Write line(s) of code that print the number of values in
my_dict
. - 2f. Change the value associated with the key
8
to'zero'
. - 2g. Suppose we have a function
sum_dict_keys
that sums the keys ofmy_dict
and returns this amount. Write a line of code that instantiates adict[str: int]
containing a single value, which is the result of callingsum_dict_keys(my_dict)
and a key of “returned_amount”.
- The following questions will refer to the dictionary below:
dict[int, str] = {0: "dog", 1: "cat", 2: "mouse", 3: "bird", 4: "whale"} my_dict:
- 3a. What will print from the following code:
for x in range(0, len(my_dict)):
print(my_dict[x])
dog, cat, mouse, bird, whale
dog, cat, mouse, bird
IndexOutOfRange
0, 1, 2, 3, 4
- 3b. What will print from the following code:
for x in range(0, len(my_dict)):
print(x)
0, 1, 2, 3, 4
dog, cat, mouse, bird, whale
IndexOutOfRange
1, 2, 3, 4
- 3c. What will print from the following code:
for x in my_dict:
print(my_dict[x])
dog, cat, mouse, bird, whale
dog, cat, mouse, bird
IndexOutOfRange
0, 1, 2, 3, 4
- 3d. What will print from the following code:
for x in my_dict:
print(x)
0, 1, 2, 3, 4
dog, cat, mouse, bird, whale
IndexOutOfRange
1, 2, 3, 4
- 3e. What will print from the following code:
int = 0
x: while x < len(my_dict):
print(x)
+= 1 x
0, 1, 2, 3, 4
dog, cat, mouse, bird, whale
IndexOutOfRange
1, 2, 3, 4, 5
- 3f. What will print from the following code:
int = 0
x: while x < len(my_dict):
print(my_dict[x])
+= 1 x
dog, cat, mouse, bird, whale
dog, cat, mouse, bird
IndexOutOfRange
0, 1, 2, 3, 4
- The following questions will refer to the dictionary below:
dict[int, str] = {8: "dog", 1: "cat", 10: "mouse", 15: "bird", 0: "whale"} my_dict:
- 4a. What will print from the following code:
for x in range(0, len(my_dict)):
print(my_dict[x])
whale, cat, KeyError
IndexOutOfRange
dog, cat, mouse
bird, whale
- 4b. What will print from the following code:
for x in range(0, len(my_dict)):
print(x)
0, 1, 2, 3, 4
0, 1, 2
IndexOutOfRange
1, 2, 3, 4
- 4c. What will print from the following code:
for x in my_dict:
print(my_dict[x])
dog, cat, mouse, bird, whale
whale, cat, mouse, bird, dog
IndexOutOfRange
0, 1, 2, 3, 4
- 4d. What will print from the following code:
for x in my_dict:
print(x)
8, 1, 10, 15, 0
dog, cat, mouse, bird, whale
IndexOutOfRange
0, 1, 2, 3, 4
- 4e. What will print from the following code:
int = 0
x: while x < len(my_dict):
print(x)
+= 1 x
0, 1, 2, 3, 4
1, 2, 3, 4
IndexOutOfRange
0, 1, 2
- 4f. What will print from the following code:
int = 0
x: while x < len(my_dict):
print(my_dict[x])
+= 1 x
whale, cat, KeyError
IndexOutOfRange
dog, cat, mouse
bird, whale
- The following questions will refer to the dictionary below:
dict[str, str] = {"cat": "dog", "dog": "cat", "bird": "mouse", "mouse": "bird", "while": "whale"} my_dict:
- 5a. What will print from the following code:
for x in range(0, len(my_dict)):
print(my_dict[x])
IndexOutOfRange
dog, cat, mouse
KeyError
bird, whale
- 5b. What will print from the following code:
for x in range(0, len(my_dict)):
print(x)
0, 1, 2, 3, 4
1, 2, 3, 4
IndexOutOfRange
0, 1, 2
- 5c. What will print from the following code:
for x in my_dict:
print(my_dict[x])
dog, cat, mouse, bird, whale
dog, cat, mouse, bird
IndexOutOfRange
cat, dog, bird
- 5d. What will print from the following code:
for x in my_dict:
print(x)
cat, dog, bird, mouse, while
dog, cat, mouse, bird
IndexOutOfRange
0, 1, 2, 3, 4
- 5e. What will print from the following code:
int = 0
x: while x < len(my_dict):
print(x)
+= 1 x
0, 1, 2, 3, 4
dog, cat, mouse, bird, whale
IndexOutOfRange
1, 2, 3, 4
- 5f. What will print from the following code:
int = 0
x: while x < len(my_dict):
print(my_dict[x])
+= 1 x
IndexOutOfRange
dog, cat, mouse
KeyError
bird, whale
Function Writing
- Write a function that will take a
list[str]
and returns alist[int]
of the size of each string in the input list. - Write a function that will take a
list[str]
and returns the sum of the lengths of all the strings. - Write a function that will take a
list[str]
and mutates the list by adding a exclamation point to each string in the input list. Your function should not return anything. - Write a function that takes a
str
input and returns a list with each element being a single character in the string input. - Write a function that takes a
int
input and creates a list of the size of your input integer. Every element should be equal to their index value. When the function is called and finishes executing and the frame goes out of scope, the new list should still be avaiable for reference to a Global varibale. - Write a function that take a
list[float]
, anint
, and afloat
and inserts thefloat
into thelist[float]
at the index specified by theint
passed to the function. - Write a function that takes a
list[int]
and returns a new list with only the even numbers. - Write a function that takes a
list[str]
and returns a new list with only the strings that contain the letter ‘a’. - Write a function that takes a
list[int]
and returns the largest number. - Write a function that takes a
str
input and counts how many times of each vowel appears in the string and returns this as a summary in a dict[str, int]. - Write a function that takes two
list[int]
and returns a new list with the elements that appear in both lists. - Write a function that takes a
list[float]
and returns the average of the list, ignoring any negative numbers. - Write a function that takes a
list[str]
and returns a new list with the strings sorted by length in descending order. - Write a function that takes a
list[str]
and returns a dictionary where the keys are the strings and the values are the lengths of each string. - Write a function that takes a
str
and returns a dict[str, int] that counts the frequency of each character in the string. - Write a function that takes a
list[str]
and returns a dictionary where the keys are the first letters of each string, and the values are lists of strings that start with that letter. - Write a function that takes a
dict[str, int]
and returns a list[str] of all the keys that have even values. - Write a function that takes a
dict[str, int]
and returns the key with the largest value. Assume the values of thedict[str, int]
will not be negative. - Write a function that takes two
dict[str, float]
and merges them into one. If both dictionaries have the same key, sum their values. - Write a function that takes a
dict[str, list[float]]
where the keys are strings and the values are lists. The function should return a new dictionary where the keys are the original keys, but the values are the lengths of each list. - Write a function that takes a
dict[float, int]
and returns a new dictionary with the keys and values swapped. - Write a function that takes a dictionary of students’ names as keys and their test scores as values, then returns a new
dict[str, int]
with only students who scored above an 85.
Solutions
- List Manipulations
list[int] = list()
my_list:
# 1a. Add the numbers 8, 0, 3, and -1 to the list.
8)
my_list.append(0)
my_list.append(3)
my_list.append(-1)
my_list.append(
# 1b. Remove the number 3 from the list.
2)
my_list.pop(
# 1c. Assign the element at the second index to a variable named 'dog'.
= my_list[2]
dog
# 1d. Print the number of items in the list.
print(len(my_list))
# 1e. Change the value 8 to 0.
0] = 0
my_list[
# 1f. Instantiate a list[int] with the first value returned from calling sum on my_list.
= [sum(my_list)] summed_list
- Dictionary Manipulations
dict[int, str] = {}
my_dict:
# 2a. Add key-value pairs to the dictionary.
8] = 'eight'
my_dict[0] = 'zero'
my_dict[3] = 'three'
my_dict[-1] = 'negative one'
my_dict[
# 2b. Remove the key-value pair where the value is 'three'.
3) # recall that pop takes an index and in the case of dictionaries or indicies are essentially our keys
my_dict.pop(
# 2c. Assign the value associated with the key 0 to a variable called 'cat'.
= my_dict[0]
cat
# 2d. Print the number of keys in the dictionary.
print(len(my_dict))
# 2e. Print the number of values in the dictionary.
print(len(my_dict))
# 2f. Change the value associated with the key 8 to 'zero'.
8] = 'zero'
my_dict[
# 2g. Instantiate a dict[str, int] with the key 'returned_amount' and the value from sum_dict_keys(my_dict).
= {'returned_amount': sum_dict_keys(my_dict)} result_dict
- Dictionary Looping and Output
- 3a: Output = (a) dog, cat, mouse, bird, whale
- 3b: Output = (a) 0, 1, 2, 3, 4
- 3c: Output = (a) dog, cat, mouse, bird, whale
- 3d: Output = (a) 0, 1, 2, 3, 4
- 3e: Output = (a) 0, 1, 2, 3, 4
- 3f: Output = (a) dog, cat, mouse, bird, whale
- Looping with Different Key Values
- 4a: Output = (a) whale, cat, KeyError
- 4b: Output = (a) 0, 1, 2, 3, 4
- 4c: Output = (a) dog, cat, mouse, bird, whale
- 4d: Output = (a) 0, 1, 8, 10, 15
- 4e: Output = (a) 0, 1, 2, 3, 4
- 4f: Output = (a) whale, cat, KeyError
- Dictionary with String Keys
- 5a: Output = (c) KeyError
- 5b: Output = (a) 0, 1, 2, 3, 4
- 5c: Output = (a) dog, cat, mouse, bird, whale
- 5d: Output = (a) cat, dog, bird, mouse, while
- 5e: Output = (a) 0, 1, 2, 3, 4
- 5f: Output = (c) KeyError
- Solution below:
def size_of_strings(strings: list[str]) -> list[int]:
"""Return a list of the size of each string in the input list."""
result: list[int] = []
for x in range(0, len(strings)):
result.append(len(strings[x]))
return result
# OR
def size_of_strings(strings: list[str]) -> list[int]:
"""Return a list of the size of each string in the input list."""
result: list[int] = []
i = 0 # Initialize a counter for the while loop
while i < len(strings): # Loop until the end of the list
string_length = 0 # Manually count the length of the string
j = 0 # Initialize a second counter to measure string length
while j < len(strings[i]): # Measure the length of each string
string_length += 1
j += 1
result.append(string_length) # Append the calculated length to result
i += 1 # Move to the next string in the list
return result
- Solution below:
def sum_of_string_lengths(strings: list[str]) -> int:
"""Return the sum of the lengths of all strings in the list."""
total_length: int = 0
for string in strings:
total_length += len(string)
return total_length
# OR
def sum_of_string_lengths(strings: list[str]) -> int:
"""Return the sum of the lengths of all strings in the list."""
total_length = 0
i = 0
while i < len(strings):
total_length += len(strings[i])
i += 1
return total_length
- Solution below:
def add_exclamation(strings: list[str]) -> None:
"""Add an exclamation point to each string in the input list."""
for i in range(len(strings)):
strings[i] += '!'
# OR
def add_exclamation(strings: list[str]) -> None:
"""Add an exclamation point to each string in the input list."""
i = 0
while i < len(strings):
strings[i] += '!'
i += 1
- Solution below:
def string_to_characters(input_string: str) -> list[str]:
"""Return a list where each element is a character from the input string."""
result: list[str] = []
for char in input_string:
result.append(char)
return result
# OR
def string_to_list(s: str) -> list[str]:
"""Convert a string into a list where each element is a character."""
result: list[str] = []
i = 0
while i < len(s):
result.append(s[i])
i += 1
return result
- Solution below:
def count_str(size: int) -> list[int]:
"""Create a list of the size of the input integer and assign it to a global variable."""
result: list[int] = []
for x in range(0, size):
result.append(x)
return result
size_list: list[int] = count_str(5)
# OR
def count_str(size: int) -> list[int]:
"""Create a list of the size of the input integer using a while loop."""
result: list[int] = []
x: int = 0
while x < size:
result.append(x)
x += 1
return result
size_list: list[int] = count_str(5)
- Solution below:
def insert_float(lst: list[float], index: int, num: float) -> list[float]:
"""Insert a float into the list at the specified index without using the insert function."""
result: list[float] = []
for x in range(0, len(lst)):
if x == index:
result.append(num) # Add the new float at the specified index
result.append(lst[x]) # Add the existing float
# If the index is at the end, append the new float after the last element
if index >= len(lst):
result.append(num)
return result
# OR
def insert_float(lst: list[float], index: int, num: float) -> list[float]:
"""Insert a float into the list at the specified index using a while loop."""
result: list[float] = []
x: int = 0
while x < len(lst):
if x == index:
result.append(num) # Add the new float at the specified index
result.append(lst[x]) # Add the existing float
x += 1 # Increment the index
# If the index is at the end, append the new float after the last element
if index >= len(lst):
result.append(num)
return result
- Solution below:
def only_evens(lst: list[int]) -> list[int]:
"""Return a new list with only the even numbers."""
result: list[int] = []
for x in range(0, len(lst)):
if lst[x] % 2 == 0:
result.append(lst[x])
return result
# OR
def only_evens(lst: list[int]) -> list[int]:
"""Return a new list with only the even numbers using a while loop."""
result: list[int] = []
x: int = 0
while x < len(lst):
if lst[x] % 2 == 0:
result.append(lst[x]) # Add even numbers to the result list
x += 1 # Increment the index
return result
- Solution below:
def only_a_strings(strings: list[str]) -> list[str]:
"""Return a new list with only the strings that contain the letter 'a' using a for loop."""
result: list[str] = []
for string in strings:
if 'a' in string: # Check if 'a' is in the current string
result.append(string)
return result
# OR
def only_a_strings(strings: list[str]) -> list[str]:
"""Return a new list with only the strings that contain the letter 'a'."""
result: list[str] = []
i: int = 0
j: int = 0
while i < len(strings):
while j < len(strings[i]):
if strings[i][j] == "a":
result.append(strings[i])
j += 1
i += 1
return result
- Solution below:
def largest_number(lst: list[int]) -> int:
"""Return the largest number in the input list."""
result: int = lst[0]
for x in range(0, len(lst)):
if lst[x] > result:
result = lst[x]
return result
# OR
def largest_number(lst: list[int]) -> int:
"""Return the largest number in the input list using a while loop."""
if len(lst) == 0: # Handle empty list case
raise ValueError("The list is empty")
result: int = lst[0]
x: int = 0
while x < len(lst):
if lst[x] > result:
result = lst[x]
x += 1 # Increment the index
return result
- Solution below:
def count_vowels(string: str) -> dict[str, int]:
"""Return a dictionary with the count of each vowel in the input string."""
result: dict[str, int] = {"a": 0, "e": 0, "i": 0, "o": 0, "u": 0}
for x in range(0, len(string)):
if string[x] in result:
result[string[x]] += 1
return result
# OR
def count_vowels(string: str) -> dict[str, int]:
"""Return a dictionary with the count of each vowel in the input string using a while loop."""
result: dict[str, int] = {"a": 0, "e": 0, "i": 0, "o": 0, "u": 0}
x: int = 0
while x < len(string):
if string[x] in result:
result[string[x]] += 1
x += 1 # Increment the index
return result
- Solution below:
def same_nums(lst1: list[int], lst2: list[int]) -> list[int]:
"""Return a new list with the elements that appear in both lists."""
result: list[int] = []
for x in range(0, len(lst1)):
for y in range(0, len(lst2)):
if lst1[x] == lst2[y]:
result.append(lst1[x])
return result
# OR
def same_nums(lst1: list[int], lst2: list[int]) -> list[int]:
"""Return a new list with the elements that appear in both lists using while loops."""
result: list[int] = []
x: int = 0
while x < len(lst1):
y: int = 0
found: bool = False # To track if a match is found
while y < len(lst2):
if lst1[x] == lst2[y]:
result.append(lst1[x])
found = True # Set found to True if a match is found
y += 1 # Increment the inner index
# Increment the outer index regardless of finding a match
x += 1
return result
- Solution below:
def average_non_negative(lst: list[float]) -> float:
"""Return the average of the list, ignoring any negative numbers."""
total: float = 0
count: int = 0
# Use a while loop to iterate through the list
index: int = 0
while index < len(lst):
if lst[index] >= 0: # Only consider non-negative numbers
total += lst[index]
count += 1 # Increment the count for valid numbers
index += 1 # Move to the next element
# Calculate and return the average
if count > 0: # Avoid division by zero
return total / count
return 0 # Return 0 if there are no non-negative numbers
- Solution below:
def sort_strings(strings: list[str]) -> list[str]:
"""Return a new list with the strings sorted by length in descending order."""
result: list[str] = []
while len(result) < len(strings):
max_index = 0
for i in range(1, len(strings)):
if len(strings[i]) > len(strings[max_index]):
max_index = i
result.append(strings[max_index])
strings[max_index] = ""
return result
# OR
def sort_strings(strings: list[str]) -> list[str]:
"""Return a new list with the strings sorted by length in descending order using while loops."""
result: list[str] = []
temp_strings: list[str] = [] # Initialize an empty list for manual copying
# Manually copy the original list to temp_strings
i: int = 0
while i < len(strings):
temp_strings.append(strings[i])
i += 1 # Increment the index
while len(result) < len(strings):
max_index = 0
j: int = 1
while j < len(temp_strings):
if len(temp_strings[j]) > len(temp_strings[max_index]):
max_index = j
j += 1 # Increment the inner index
result.append(temp_strings[max_index]) # Append the longest string to result
temp_strings[max_index] = "" # Mark the string as used by replacing it with an empty string
return result
- Solution below:
def strings_to_dict(strings: list[str]) -> dict[str, int]:
"""Return a dictionary where the keys are the strings and the values are the lengths of each string."""
result: dict[str, int] = {}
for x in range(0, len(strings)):
result[strings[x]] = len(strings[x])
return result
# OR
def strings_to_dict(strings: list[str]) -> dict[str, int]:
"""Return a dictionary where the keys are the strings and the values are the lengths of each string using a while loop."""
result: dict[str, int] = {}
x: int = 0
while x < len(strings):
result[strings[x]] = len(strings[x]) # Assign the string as key and its length as value
x += 1 # Increment the index
return result
- Solution below:
def count_chars(string: str) -> dict[str, int]:
"""Return a dictionary with the frequency of each character in the input string."""
result: dict[str, int] = {}
for x in range(0, len(string)):
if string[x] in result:
result[string[x]] += 1
else:
result[string[x]] = 1
return result
# OR
def count_chars(string: str) -> dict[str, int]:
"""Return a dictionary with the frequency of each character in the input string using a while loop."""
result: dict[str, int] = {}
x: int = 0
while x < len(string):
if string[x] in result:
result[string[x]] += 1 # Increment the count if the character already exists
else:
result[string[x]] = 1 # Initialize the count for the character
x += 1 # Increment the index
return result
- Solution below:
def group_strings_by_first_letter(strings: list[str]) -> dict[str, list[str]]:
"""Return a dictionary where the keys are the first letters and the values are lists of strings starting with that letter."""
result: dict[str, list[str]] = {}
# Use a while loop to iterate through the list of strings
index: int = 0
while index < len(strings):
if strings[index]: # Ensure the string is not empty
first_letter: str = strings[index][0] # Get the first letter
# If the first letter is not in the result dictionary, add it with an empty list
if first_letter not in result:
result[first_letter] = []
result[first_letter].append(strings[index]) # Add the string to the appropriate list
index += 1 # Move to the next string
return result
# OR
def find_first_letter(strings: list[str]) -> dict[str, list[str]]:
"""Return a dictionary with the first letter of each string as the key and a list of strings that start with that letter as the value."""
result: dict[str, list[str]] = {}
for x in range(0, len(strings)):
if strings[x][0] in result:
result[strings[x][0]].append(strings[x])
else:
result[strings[x][0]] = [strings[x]]
return result
- Solution below:
def keys_with_even_values(d: dict[str, int]) -> list[str]:
"""Return a list of keys that have even values."""
result: list[str] = []
for key in d:
if d[key] % 2 == 0:
result.append(key)
return result
# OR
def keys_with_even_values(d: dict[str, int]) -> list[str]:
"""Return a list of keys that have even values using a while loop."""
result: list[str] = []
keys: list[str] = [] # Initialize an empty list for keys
x: int = 0
# Manually collect keys from the dictionary
for key in d: # Use a for loop just to collect keys
keys.append(key)
while x < len(keys):
if d[keys[x]] % 2 == 0:
result.append(keys[x]) # Append the key if its value is even
x += 1 # Increment the index
return result
- Solution below:
def key_with_largest_value(d: dict[str, int]) -> str:
"""Return the key with the largest value in the input dictionary."""
largest_key: str = ""
largest_value: int = 0
# Use a for loop to iterate through the dictionary
for key in d:
if d[key] > largest_value:
largest_value = d[key] # Update largest value
largest_key = key # Update largest key
return largest_key
# OR
def key_with_largest_value(d: dict[str, int]) -> str:
"""Return the key with the largest value in the input dictionary."""
largest_key: str = ""
largest_value: int = 0
index: int = 0
# Manually create a list of keys from the dictionary
keys: list[str] = []
# Populate keys manually
while index < len(d):
current_key = next(iter(d)) # Get the first key from the dictionary
keys.append(current_key) # Add the key to the list of keys
d.pop(current_key) # Remove the key from the dictionary to avoid duplicates
index += 1
# Use a while loop to find the key with the largest value
x: int = 0 # Index for the keys
while x < len(keys):
key = keys[x]
if key in d and d[key] > largest_value:
largest_value = d[key] # Update largest value
largest_key = key # Update largest key
x += 1 # Increment the index
return largest_key
- Solution below:
def merge_dicts(d1: dict[str, float], d2: dict[str, float]) -> dict[str, float]:
"""Merge two dictionaries into one, summing the values of common keys."""
result: dict[str, float] = {}
for key in d1:
result[key] = d1[key]
for key in d2:
if key in result:
result[key] += d2[key]
else:
result[key] = d2[key]
return result
# OR
def merge_dicts(d1: dict[str, float], d2: dict[str, float]) -> dict[str, float]:
"""Merge two dictionaries into one, summing the values of common keys using a while loop."""
result: dict[str, float] = {}
keys1: list[str] = [] # Manually create a list for keys in d1
keys2: list[str] = [] # Manually create a list for keys in d2
# Populate keys1 and keys2 manually
for key in d1:
keys1.append(key)
for key in d2:
keys2.append(key)
x: int = 0 # Index for keys1
# Use a while loop to add keys from d1 to the result
while x < len(keys1):
key = keys1[x]
result[key] = d1[key] # Add key and value from d1 to result
x += 1 # Increment index
y: int = 0 # Index for keys2
# Use another while loop to process keys from d2
while y < len(keys2):
key = keys2[y]
if key in result:
result[key] += d2[key] # Sum the values for common keys
else:
result[key] = d2[key] # Add new keys and values to result
y += 1 # Increment index
return result
- Solution below:
def length_of_values(d: dict[str, list[float]]) -> dict[str, int]:
"""Return a dictionary with the lengths of the lists in the input dictionary."""
result: dict[str, int] = {}
for key in d:
result[key] = len(d[key])
return result
- Solution below:
def swap_keys_values(d: dict[float, int]) -> dict[int, float]:
"""Return a new dictionary with the keys and values swapped."""
result: dict[int, float] = {}
for key in d:
result[d[key]] = key
return result
- Solution below:
def find_above_85(d: dict[str, int]) -> dict[str, int]:
"""Return a new dictionary with only the students who scored above an 85."""
result: dict[str, int] = {}
for key in d:
if d[key] > 85:
result[key] = d[key]
return result