Skip to content

Instantly share code, notes, and snippets.

@IvanFrecia
Created April 29, 2021 22:50
Show Gist options
  • Save IvanFrecia/56aad370ab2e505fa0db0dca9d387beb to your computer and use it in GitHub Desktop.
Save IvanFrecia/56aad370ab2e505fa0db0dca9d387beb to your computer and use it in GitHub Desktop.
Coursera - Python 3 Programming Specialization - Functions Files and Dictionaries - Week2 - Assessment Dictionary Accumulation
# Assessment: Dictionary Accumulation - course_2_assessment_3
# 1) The dictionary Junior shows a schedule for a junior year semester.
# The key is the course name and the value is the number of credits.
# Find the total number of credits taken this semester and assign it to the variable credits.
# Do not hardcode this – use dictionary accumulation!
# Answer:
Junior = {'SI 206':4, 'SI 310':4, 'BL 300':3, 'TO 313':3, 'BCOM 350':1, 'MO 300':3}
credits = 0
for credit in Junior:
credits = credits + Junior[credit]
print(credits)
# 2) Create a dictionary, freq, that displays each character in string str1 as the key and its frequency as the value.
# Answer:
str1 = "peter piper picked a peck of pickled peppers"
freq = {}
for char in str1:
if char not in freq:
freq[char] = 0
freq[char] += 1
print(freq)
# 3) Provided is a string saved to the variable name s1.
# Create a dictionary named counts that contains each letter in s1 and the number of times it occurs.
# Answer:
s1 = "hello"
counts = {}
for letter in s1:
if letter not in counts:
counts[letter] = 0
counts[letter] += 1
print(counts)
# 4) Create a dictionary, freq_words, that contains each word in string str1 as the key and its frequency as the value.
# Answer:
str1 = "I wish I wish with all my heart to fly with dragons in a land apart"
words = str1.split()
freq_words = {}
for word in words:
if word not in freq_words:
freq_words[word] = 0
freq_words[word] += 1
print(freq_words)
# 5) Create a dictionary called wrd_d from the string sent, so that the key is a word and the value is how many times
# you have seen that word.
# Answer:
sent = "Singing in the rain and playing in the rain are two entirely different situations but both can be good"
words = sent.split()
wrd_d = {}
for word in words:
if word not in wrd_d:
wrd_d[word] = 0
wrd_d[word] += 1
print(wrd_d)
# 6) Create the dictionary characters that shows each character from the string sally and its frequency.
# Then, find the most frequent letter based on the dictionary. Assign this letter to the variable best_char.
# Answer:
sally = "sally sells sea shells by the sea shore"
characters = {}
for chars in sally:
if chars not in characters:
characters[chars] = 0
characters[chars] = characters[chars] + 1
keys = list(characters.keys())
best_char = keys[0]
for key in keys:
if characters[key] > characters[best_char]:
best_char = key
print(characters)
print(best_char)
# 7) Find the least frequent letter. Create the dictionary characters that shows each character from string sally and its frequency.
# Then, find the least frequent letter in the string and assign the letter to the variable worst_char.
# Answer:
sally = "sally sells sea shells by the sea shore and by the road"
characters = {}
for chars in sally:
if chars not in characters:
characters[chars] = 0
characters[chars] = characters[chars] + 1
keys = list(characters.keys())
worst_char = keys[0]
for key in keys:
if characters[key] < characters[worst_char]:
worst_char = key
print(characters)
print(worst_char)
# 8) Create a dictionary named letter_counts that contains each letter and the number of times it occurs in string1.
# Challenge: Letters should not be counted separately as upper-case and lower-case. Intead, all of them should be counted as lower-case.
# Answer:
string1 = "There is a tide in the affairs of men, Which taken at the flood, leads on to fortune. Omitted, all the voyage of their life is bound in shallows and in miseries. On such a full sea are we now afloat. And we must take the current when it serves, or lose our ventures."
letter_counts = {}
for char in string1.lower():
if char not in letter_counts:
letter_counts[char] = 0
letter_counts[char] = letter_counts[char] + 1
print(letter_counts)
# 9) Create a dictionary called low_d that keeps track of all the characters in the string p and notes how many times each character was seen.
# Make sure that there are no repeats of characters as keys, such that “T” and “t” are both seen as a “t” for example.
# Answer:
p = "Summer is a great time to go outside. You have to be careful of the sun though because of the heat."
low_d = {}
for char in p.lower():
if char not in low_d:
low_d[char] = 0
low_d[char] = low_d[char] +1
print(low_d)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment