Compare commits
58 Commits
adventure-
...
master
Author | SHA1 | Date |
---|---|---|
|
68a61a4b59 | |
|
db5d2fcff3 | |
|
f8530d6f43 | |
|
7badebfecb | |
|
e1e8b21904 | |
|
fe4c7b3701 | |
|
8e662c58bf | |
|
030dd0b611 | |
|
83fb61e63b | |
|
23eec468cf | |
|
b7f73fb1f0 | |
|
b434e7f74f | |
|
763af28c36 | |
|
4fab27a9b0 | |
|
1a9d1f6386 | |
|
50b32271e2 | |
|
d97e42d717 | |
|
6bef49c6b2 | |
|
ba5ac1f29a | |
|
8391478991 | |
|
291fc92aa6 | |
|
f609162053 | |
|
6690d9cdf4 | |
|
49f7781e86 | |
|
5e9c248e2f | |
|
52e2472d13 | |
|
7b097ae89f | |
|
3d2870eb2c | |
|
048c002e69 | |
|
2bbeb9da06 | |
|
d67fa51d83 | |
|
386a40fc70 | |
|
549923cc01 | |
|
0674442945 | |
|
9863e910f6 | |
|
6bcb5be1ec | |
|
5ea69d0956 | |
|
8ec38fd2ea | |
|
5546a6d8f9 | |
|
d592cc5b0b | |
|
9f9c84428c | |
|
149df344ce | |
|
ca1e52929c | |
|
97bc27ebd1 | |
|
ab881dd578 | |
|
d27d5025fb | |
|
cb99c6af49 | |
|
f5ef14dee8 | |
|
247b241041 | |
|
1b92f1d3f6 | |
|
89b8c97671 | |
|
6d9c78c801 | |
|
e08e312789 | |
|
a79e01ee28 | |
|
2f215aa45b | |
|
970aa86bcb | |
|
9b128a8a96 | |
|
e494261948 |
|
@ -0,0 +1,3 @@
|
||||||
|
# Default ignored files
|
||||||
|
/shelf/
|
||||||
|
/workspace.xml
|
|
@ -0,0 +1,11 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<module type="PYTHON_MODULE" version="4">
|
||||||
|
<component name="NewModuleRootManager">
|
||||||
|
<content url="file://$MODULE_DIR$" />
|
||||||
|
<orderEntry type="inheritedJdk" />
|
||||||
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
|
</component>
|
||||||
|
<component name="TestRunnerService">
|
||||||
|
<option name="PROJECT_TEST_RUNNER" value="pytest" />
|
||||||
|
</component>
|
||||||
|
</module>
|
|
@ -0,0 +1,6 @@
|
||||||
|
<component name="InspectionProjectProfileManager">
|
||||||
|
<settings>
|
||||||
|
<option name="USE_PROJECT_PROFILE" value="false" />
|
||||||
|
<version value="1.0" />
|
||||||
|
</settings>
|
||||||
|
</component>
|
|
@ -0,0 +1,4 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.7" project-jdk-type="Python SDK" />
|
||||||
|
</project>
|
|
@ -0,0 +1,8 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectModuleManager">
|
||||||
|
<modules>
|
||||||
|
<module fileurl="file://$PROJECT_DIR$/.idea/2-3.iml" filepath="$PROJECT_DIR$/.idea/2-3.iml" />
|
||||||
|
</modules>
|
||||||
|
</component>
|
||||||
|
</project>
|
|
@ -0,0 +1,6 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="VcsDirectoryMappings">
|
||||||
|
<mapping directory="$PROJECT_DIR$/../.." vcs="Git" />
|
||||||
|
</component>
|
||||||
|
</project>
|
Binary file not shown.
Binary file not shown.
|
@ -0,0 +1,20 @@
|
||||||
|
import datetime
|
||||||
|
|
||||||
|
|
||||||
|
def prompt_user():
|
||||||
|
name = input('What is your name? ')
|
||||||
|
try:
|
||||||
|
age = int(input('How old are you? '))
|
||||||
|
except ValueError:
|
||||||
|
return 'Age must be a number.'
|
||||||
|
|
||||||
|
return 'Hello {0}! You were born in {1}.'.format(name, get_year() - age)
|
||||||
|
|
||||||
|
|
||||||
|
def get_year():
|
||||||
|
now = datetime.datetime.now()
|
||||||
|
return now.year
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
print(prompt_user())
|
|
@ -0,0 +1,20 @@
|
||||||
|
|
||||||
|
def output_format_one(first, middle, last):
|
||||||
|
_format = "{0}, {1}.".format(last, first[0])
|
||||||
|
return _format
|
||||||
|
|
||||||
|
def output_format_two(first, middle, last):
|
||||||
|
_format = "{0}, {1}.{2}.".format(last, first[0], middle[0])
|
||||||
|
return _format
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
name = input("Input your name: ")
|
||||||
|
|
||||||
|
name = name.split(' ')
|
||||||
|
|
||||||
|
if len(name) == 2:
|
||||||
|
name = output_format_one(name[0], None, name[1])
|
||||||
|
elif len(name) == 3:
|
||||||
|
name = output_format_two(name[0], name[1], name[2])
|
||||||
|
|
||||||
|
print(name)
|
|
@ -0,0 +1,15 @@
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
_input = input()
|
||||||
|
|
||||||
|
character, phrase = [_input.split(' ', 1)[i] for i in range(2)]
|
||||||
|
|
||||||
|
frequency = phrase.count(character)
|
||||||
|
frequency_nocase = phrase.upper().count(character.upper())
|
||||||
|
|
||||||
|
if frequency != 0:
|
||||||
|
print(frequency)
|
||||||
|
#elif frequency_nocase > 0: # Lol im stupid~
|
||||||
|
# print("{0} is diferent than {1}.".format(character, character.upper()))
|
||||||
|
if frequency == 0 & frequency_nocase == 0:
|
||||||
|
print(frequency)
|
|
@ -0,0 +1,16 @@
|
||||||
|
if __name__ == '__main__':
|
||||||
|
favorite_color = input('Enter favorite color:\n')
|
||||||
|
pets_name = input('Enter pet\'s name:\n')
|
||||||
|
favorite_number = input('Enter a number:\n')
|
||||||
|
|
||||||
|
print('You entered: {0} {1} {2}\n'.format(favorite_color, pets_name, favorite_number))
|
||||||
|
|
||||||
|
first_password = '{0}_{1}'.format(favorite_color, pets_name)
|
||||||
|
second_password = '{0}{1}{0}'.format(favorite_number, favorite_color)
|
||||||
|
|
||||||
|
print('First password: {0}'.format(first_password))
|
||||||
|
print('Second password: {0}\n'.format(second_password))
|
||||||
|
|
||||||
|
print('Number of characters in {0}: {1}'.format(first_password, len(first_password)))
|
||||||
|
print('Number of characters in {0}: {1}'.format(second_password, len(second_password)))
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
def collect_grades():
|
||||||
|
grades = []
|
||||||
|
print('Enter a score on an exam. If the weight is different than x/100 specify using (grade)/(weight).')
|
||||||
|
while True:
|
||||||
|
_input = input('''Enter a score on an exam. ( 93 OR 93/100)\n(Press enter to stop):\n''')
|
||||||
|
if len(_input) == 0:
|
||||||
|
break
|
||||||
|
grades.append(_input)
|
||||||
|
return grades
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
print(collect_grades())
|
||||||
|
|
||||||
|
exam1_grade = float(input('Enter score on Exam 1 (out of 100):\n'))
|
||||||
|
exam2_grade = float(input('Enter score on Exam 2 (out of 100):\n'))
|
||||||
|
exam3_grade = float(input('Enter score on Exam 3 (out of 100):\n'))
|
||||||
|
|
||||||
|
overall_grade = (exam1_grade + exam2_grade + exam3_grade) / 3
|
||||||
|
|
||||||
|
print('Your overall grade is:', overall_grade)
|
|
@ -0,0 +1,13 @@
|
||||||
|
tweet = input('Enter abbreviation from tweet:\n')
|
||||||
|
|
||||||
|
tweet_dict = {
|
||||||
|
'LOL': 'LOL = laughing out loud',
|
||||||
|
'BFN': 'BFN = bye for now',
|
||||||
|
'FTW': 'FTW = for the win',
|
||||||
|
'IRL': 'IRL = in real life'
|
||||||
|
}
|
||||||
|
|
||||||
|
try:
|
||||||
|
print(tweet_dict[tweet.upper()])
|
||||||
|
except KeyError:
|
||||||
|
print("Sorry, don't know that one")
|
|
@ -0,0 +1,16 @@
|
||||||
|
|
||||||
|
def get_input():
|
||||||
|
result = []
|
||||||
|
print('Enter a number when prompted. Press enter to stop')
|
||||||
|
while True:
|
||||||
|
_input = input('Input a number: ')
|
||||||
|
if len(_input) == 0:
|
||||||
|
break
|
||||||
|
try:
|
||||||
|
_input = int(_input)
|
||||||
|
result.append(_input)
|
||||||
|
except ValueError:
|
||||||
|
print("Error, only accepts numbers")
|
||||||
|
return result
|
||||||
|
|
||||||
|
print(min(get_input()))
|
|
@ -0,0 +1,53 @@
|
||||||
|
from datetime import datetime
|
||||||
|
import logging
|
||||||
|
|
||||||
|
logging.basicConfig(level=logging.ERROR)
|
||||||
|
|
||||||
|
input_month = input('Input a month to analyse: ')
|
||||||
|
input_day = int(input('Input a day of that month: '))
|
||||||
|
|
||||||
|
def convert_doy_to_season(doy):
|
||||||
|
if not isinstance(doy, int):
|
||||||
|
return 'Invalid'
|
||||||
|
|
||||||
|
if 79 <= doy <= 171:
|
||||||
|
return 'Spring'
|
||||||
|
if 172 <= doy <= 264:
|
||||||
|
return 'Summer'
|
||||||
|
if 265 <= doy <= 354:
|
||||||
|
return 'Autumn'
|
||||||
|
if 355 <= doy <= 365 or 1 <= doy <= 78:
|
||||||
|
return 'Winter'
|
||||||
|
|
||||||
|
def convert_month_to_num(month_name):
|
||||||
|
try:
|
||||||
|
_date = datetime.strptime(month_name, "%B")
|
||||||
|
logging.debug(_date.month)
|
||||||
|
return int(_date.month)
|
||||||
|
except ValueError:
|
||||||
|
logging.warning('Was unable to convert from full month name, trying with shortname.')
|
||||||
|
try:
|
||||||
|
_date = datetime.strptime(month_name, "%b")
|
||||||
|
logging.debug(_date.month)
|
||||||
|
return int(_date.month)
|
||||||
|
except ValueError:
|
||||||
|
logging.error('Was unable to convert the month {0}! Tried long name and short name.'.format(month_name))
|
||||||
|
return None
|
||||||
|
|
||||||
|
def day_of_year(month,day):
|
||||||
|
try:
|
||||||
|
# Cannot handle leap years!!!
|
||||||
|
if day > 30 or day <= 0:
|
||||||
|
raise OverflowError
|
||||||
|
|
||||||
|
result = int((275 * month) / 9.0) - 2 * int((month + 9) / 12.0) + day - 30
|
||||||
|
logging.debug(result)
|
||||||
|
return result
|
||||||
|
except TypeError:
|
||||||
|
return None
|
||||||
|
except OverflowError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
print(convert_doy_to_season(day_of_year(convert_month_to_num(input_month), input_day)))
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
try:
|
||||||
|
user_cents = int(input('Cents: '))
|
||||||
|
except ValueError:
|
||||||
|
print('Cannot cannot parse input.')
|
||||||
|
exit()
|
||||||
|
|
||||||
|
change = []
|
||||||
|
coins = [
|
||||||
|
['Dollars', 'Dollar'],
|
||||||
|
['Quarters', 'Quarter'],
|
||||||
|
['Dimes', 'Dime'],
|
||||||
|
['Nickels', 'Nickel'],
|
||||||
|
['Pennies', 'Penny']]
|
||||||
|
|
||||||
|
while user_cents >= 100:
|
||||||
|
user_cents -= 100
|
||||||
|
change.append(coins[0])
|
||||||
|
while user_cents >= 25:
|
||||||
|
user_cents -= 25
|
||||||
|
change.append(coins[1])
|
||||||
|
while user_cents >= 10:
|
||||||
|
user_cents -= 10
|
||||||
|
change.append(coins[2])
|
||||||
|
while user_cents >= 5:
|
||||||
|
user_cents -= 5
|
||||||
|
change.append(coins[3])
|
||||||
|
for _i in range(user_cents):
|
||||||
|
change.append(coins[4])
|
||||||
|
|
||||||
|
if len(change) != 0:
|
||||||
|
for coin in coins:
|
||||||
|
num_coins = change.count(coin)
|
||||||
|
if num_coins != 0:
|
||||||
|
if num_coins > 1:
|
||||||
|
print('{0} {1}'.format(num_coins, coin[0]))
|
||||||
|
else:
|
||||||
|
print('{0} {1}'.format(num_coins, coin[1]))
|
||||||
|
else:
|
||||||
|
print('No change ')
|
||||||
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
user_score = 0
|
||||||
|
simon_pattern = input()
|
||||||
|
user_pattern = input()
|
||||||
|
|
||||||
|
#user_score = sum(a==b for a, b in zip(simon_pattern, user_pattern))
|
||||||
|
|
||||||
|
for char in enumerate(list(simon_pattern)):
|
||||||
|
if user_pattern[char[0]] == char[1]:
|
||||||
|
user_score += 1
|
||||||
|
else:
|
||||||
|
break
|
||||||
|
|
||||||
|
print('User score:', user_score)
|
|
@ -0,0 +1,12 @@
|
||||||
|
user_text = input()
|
||||||
|
|
||||||
|
autograder_exceptions = ['!']
|
||||||
|
|
||||||
|
def count_letters(string):
|
||||||
|
result = 0;
|
||||||
|
for letter in list(string):
|
||||||
|
if letter.isalpha() or letter in autograder_exceptions:
|
||||||
|
result += 1
|
||||||
|
return(result)
|
||||||
|
|
||||||
|
print(count_letters(user_text))
|
|
@ -0,0 +1,15 @@
|
||||||
|
password = input()
|
||||||
|
|
||||||
|
replacements = {
|
||||||
|
'i' : '!',
|
||||||
|
'a' : '@',
|
||||||
|
'm' : 'M',
|
||||||
|
'B' : '8',
|
||||||
|
'o' : '.'
|
||||||
|
}
|
||||||
|
|
||||||
|
for replace, replacement in replacements.items():
|
||||||
|
password = password.replace(replace, replacement)
|
||||||
|
password += 'q*s'
|
||||||
|
|
||||||
|
print(password)
|
|
@ -0,0 +1,8 @@
|
||||||
|
triangle_char = input('Enter a character:\n')
|
||||||
|
triangle_height = int(input('Enter triangle height:\n'))
|
||||||
|
print('')
|
||||||
|
|
||||||
|
for row in range(1, triangle_height + 1):
|
||||||
|
for col in range(row):
|
||||||
|
print(triangle_char, end=' ')
|
||||||
|
print('')
|
|
@ -0,0 +1,42 @@
|
||||||
|
|
||||||
|
# Construct a mad lib
|
||||||
|
class mad_lib:
|
||||||
|
|
||||||
|
# Initalize a constructor for python mad lib
|
||||||
|
def __init__(self, lib):
|
||||||
|
# lib is a value passed in during the construction of this class
|
||||||
|
self.text = lib
|
||||||
|
self.input = input().split()
|
||||||
|
|
||||||
|
# Replace %text% with user input
|
||||||
|
if '%first_name%' in self.text:
|
||||||
|
self.text = self.text.replace('%first_name%', self.first_name())
|
||||||
|
if '%location%' in self.text:
|
||||||
|
self.text = self.text.replace('%location%', self.location())
|
||||||
|
if '%whole_number%' in self.text:
|
||||||
|
self.text = self.text.replace('%whole_number%', self.whole_number())
|
||||||
|
if '%plural_noun%' in self.text:
|
||||||
|
self.text = self.text.replace('%plural_noun%', self.plural_noun())
|
||||||
|
|
||||||
|
|
||||||
|
def first_name(self):
|
||||||
|
#return input("A first name: ")
|
||||||
|
return self.input.pop()
|
||||||
|
|
||||||
|
def location(self):
|
||||||
|
#return input("A location: ")
|
||||||
|
return self.input.pop()
|
||||||
|
|
||||||
|
def whole_number(self):
|
||||||
|
#return input("A whole number: ")
|
||||||
|
return self.input.pop()
|
||||||
|
|
||||||
|
def plural_noun(self):
|
||||||
|
#return input("A plural noun: ")
|
||||||
|
return self.input.pop()
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
# Construct a mad lib
|
||||||
|
md = mad_lib('%first_name% went to %location% to buy %whole_number% different types of %plural_noun%')
|
||||||
|
|
||||||
|
print(md.text)
|
|
@ -0,0 +1,8 @@
|
||||||
|
from mad_lib import mad_lib
|
||||||
|
|
||||||
|
while True:
|
||||||
|
md = mad_lib('Eating %whole_number% %plural_noun% a day keeps the doctor away.')
|
||||||
|
if 'quit' in md.text:
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
print(md.text)
|
|
@ -0,0 +1,5 @@
|
||||||
|
user_num = int(input())
|
||||||
|
|
||||||
|
while user_num >= 1:
|
||||||
|
user_num = user_num / 2 # We operate on the value first, before printing it
|
||||||
|
print(user_num)
|
|
@ -0,0 +1,9 @@
|
||||||
|
num_insects = int(input()) # Must be >= 1
|
||||||
|
|
||||||
|
result = []
|
||||||
|
|
||||||
|
while num_insects <= 100:
|
||||||
|
result.append(num_insects)
|
||||||
|
num_insects = num_insects * 2
|
||||||
|
|
||||||
|
print(*result, end = ' ')
|
|
@ -0,0 +1,12 @@
|
||||||
|
contact_emails = {
|
||||||
|
'Sue Reyn' : 's.reyn@email.com',
|
||||||
|
'Mike Filt': 'mike.filt@bmail.com',
|
||||||
|
'Nate Arty': 'narty042@nmail.com'
|
||||||
|
}
|
||||||
|
|
||||||
|
new_contact = input()
|
||||||
|
new_email = input()
|
||||||
|
contact_emails[new_contact] = new_email
|
||||||
|
|
||||||
|
for contact in contact_emails:
|
||||||
|
print('{0} is {1}'.format(contact_emails.get(contact), contact))
|
|
@ -0,0 +1,8 @@
|
||||||
|
num_rows = int(input())
|
||||||
|
num_cols = int(input())
|
||||||
|
|
||||||
|
for _i in range(num_rows):
|
||||||
|
print('*', end=' ')
|
||||||
|
for _i in range(num_cols - 1):
|
||||||
|
print('*', end=' ')
|
||||||
|
print()
|
|
@ -0,0 +1,11 @@
|
||||||
|
num_rows = int(input())
|
||||||
|
num_cols = int(input())
|
||||||
|
|
||||||
|
# Note 1: You will need to declare more variables
|
||||||
|
# Note 2: Place end=' ' at the end of your print statement to separate seats by spaces
|
||||||
|
|
||||||
|
for row_num in range(1, num_rows + 1):
|
||||||
|
for col_char in map(chr, range(ord('A'), ord('A') + num_cols)):
|
||||||
|
print('{0}{1}'.format(row_num, col_char), end=' ')
|
||||||
|
|
||||||
|
print()
|
|
@ -0,0 +1,9 @@
|
||||||
|
|
||||||
|
def swap(list):
|
||||||
|
m_list = list[0], list[-1] = list[-1], list[0]
|
||||||
|
return m_list
|
||||||
|
|
||||||
|
values_list = input().split(',') # Program receives comma-separated values like 5,4,12,19
|
||||||
|
swap(values_list)
|
||||||
|
|
||||||
|
print(values_list)
|
|
@ -0,0 +1,12 @@
|
||||||
|
gas_const = 8.3144621
|
||||||
|
|
||||||
|
def compute_gas_volume(pressure, temperature, moles):
|
||||||
|
return (moles * gas_const * temperature) / pressure
|
||||||
|
|
||||||
|
gas_pressure = float(input())
|
||||||
|
gas_moles = float(input())
|
||||||
|
gas_temperature = float(input())
|
||||||
|
gas_volume = 0.0
|
||||||
|
|
||||||
|
gas_volume = compute_gas_volume(gas_pressure, gas_temperature, gas_moles)
|
||||||
|
print('Gas volume:', gas_volume, 'm^3')
|
|
@ -0,0 +1,6 @@
|
||||||
|
def swap_values(user_val1, user_val2):
|
||||||
|
return user_val2, user_val1
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
val1, val2 = swap_values(input(), input())
|
||||||
|
print('{0} {1}'.format(val1, val2))
|
|
@ -0,0 +1,46 @@
|
||||||
|
coins = [
|
||||||
|
['Dollars', 'Dollar'],
|
||||||
|
['Quarters', 'Quarter'],
|
||||||
|
['Dimes', 'Dime'],
|
||||||
|
['Nickels', 'Nickel'],
|
||||||
|
['Pennies', 'Penny']]
|
||||||
|
|
||||||
|
def coin_enumeration(change):
|
||||||
|
if len(change) != 0:
|
||||||
|
for coin in coins:
|
||||||
|
num_coins = change.count(coin)
|
||||||
|
if num_coins != 0:
|
||||||
|
if num_coins > 1:
|
||||||
|
print('{0} {1}'.format(num_coins, coin[0].lower()))
|
||||||
|
else:
|
||||||
|
print('{0} {1}'.format(num_coins, coin[1].lower()))
|
||||||
|
else:
|
||||||
|
print('no change')
|
||||||
|
|
||||||
|
def fit_coin(to_make, coin_val):
|
||||||
|
num_coin = to_make // coin_val
|
||||||
|
remainder = to_make - (num_coin * coin_val)
|
||||||
|
|
||||||
|
return num_coin, remainder
|
||||||
|
|
||||||
|
def exact_change(input_val):
|
||||||
|
nd, input_val = fit_coin(input_val, 100)
|
||||||
|
nq, input_val = fit_coin(input_val, 25)
|
||||||
|
ndime, input_val = fit_coin(input_val, 10)
|
||||||
|
nn, input_val = fit_coin(input_val, 5)
|
||||||
|
np, input_val = fit_coin(input_val, 1)
|
||||||
|
|
||||||
|
return nd, nq, ndime, nn, np
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
change = []
|
||||||
|
input_val = int(input())
|
||||||
|
num_dollars, num_quarters, num_dimes, num_nickels, num_pennies = exact_change(input_val)
|
||||||
|
|
||||||
|
change.extend([coins[0] for i in range(num_dollars)])
|
||||||
|
change.extend([coins[1] for i in range(num_quarters)])
|
||||||
|
change.extend([coins[2] for i in range(num_dimes)])
|
||||||
|
change.extend([coins[3] for i in range(num_nickels)])
|
||||||
|
change.extend([coins[4] for i in range(num_pennies)])
|
||||||
|
|
||||||
|
coin_enumeration(change)
|
|
@ -0,0 +1,19 @@
|
||||||
|
def find_max(num_1, num_2):
|
||||||
|
max_val = 0.0
|
||||||
|
|
||||||
|
if (num_1 > num_2): # if num1 is greater than num2,
|
||||||
|
max_val = num_1 # then num1 is the maxVal.
|
||||||
|
else: # Otherwise,
|
||||||
|
max_val = num_2 # num2 is the maxVal
|
||||||
|
return max_val
|
||||||
|
|
||||||
|
max_sum = 0.0
|
||||||
|
|
||||||
|
num_a = float(input())
|
||||||
|
num_b = float(input())
|
||||||
|
num_y = float(input())
|
||||||
|
num_z = float(input())
|
||||||
|
|
||||||
|
max_sum = sum([max([num_a, num_b]), max([num_y, num_z])])
|
||||||
|
|
||||||
|
print('max_sum is:', max_sum)
|
|
@ -0,0 +1,9 @@
|
||||||
|
|
||||||
|
def pyramid_volume(base_length, base_width, pyramid_height):
|
||||||
|
return(((base_length * base_width) * pyramid_height) * (1/3))
|
||||||
|
|
||||||
|
|
||||||
|
length = float(input())
|
||||||
|
width = float(input())
|
||||||
|
height = float(input())
|
||||||
|
print('Volume for 4.5, 2.1, 3.0 is:', pyramid_volume(length, width, height))
|
|
@ -0,0 +1,8 @@
|
||||||
|
|
||||||
|
def mph_and_minutes_to_miles(mph, dt):
|
||||||
|
return (dt / 60) * mph
|
||||||
|
|
||||||
|
miles_per_hour = float(input())
|
||||||
|
minutes_traveled = float(input())
|
||||||
|
|
||||||
|
print('Miles: {:f}'.format(mph_and_minutes_to_miles(miles_per_hour, minutes_traveled)))
|
|
@ -0,0 +1,22 @@
|
||||||
|
|
||||||
|
def get_user_num():
|
||||||
|
# This is bad practice, you should use python ABC or raise NotImplementedError instead.
|
||||||
|
print('FIXME: Finish get_user_num()')
|
||||||
|
return -1
|
||||||
|
#raise NotImplementedError
|
||||||
|
|
||||||
|
def compute_avg(user_num1, user_num2):
|
||||||
|
# This is bad practice, you should use python ABC or raise NotImplementedError instead.
|
||||||
|
print('FIXME: Finish compute_avg()')
|
||||||
|
return -1
|
||||||
|
#raise NotImplementedError
|
||||||
|
|
||||||
|
user_num1 = 0
|
||||||
|
user_num2 = 0
|
||||||
|
avg_result = 0
|
||||||
|
|
||||||
|
user_num1 = get_user_num()
|
||||||
|
user_num2 = get_user_num()
|
||||||
|
avg_result = compute_avg(user_num1, user_num2)
|
||||||
|
|
||||||
|
print('Avg:', avg_result)
|
|
@ -0,0 +1,12 @@
|
||||||
|
|
||||||
|
def print_popcorn_time(bag_ounces):
|
||||||
|
if bag_ounces < 3:
|
||||||
|
print('Too small') # This should be returned instead.
|
||||||
|
elif bag_ounces > 10:
|
||||||
|
print('Too large') # This should be returned instead.
|
||||||
|
else:
|
||||||
|
print('{0} seconds'.format(6 * bag_ounces)) # This should be returned instead.
|
||||||
|
|
||||||
|
|
||||||
|
user_ounces = int(input())
|
||||||
|
print_popcorn_time(user_ounces)
|
|
@ -0,0 +1,13 @@
|
||||||
|
|
||||||
|
def shampoo_instructions(num_cycles):
|
||||||
|
if num_cycles < 1:
|
||||||
|
print('Too few.')
|
||||||
|
elif num_cycles > 4:
|
||||||
|
print('Too many.')
|
||||||
|
else:
|
||||||
|
for i in range(num_cycles):
|
||||||
|
print('{0} : Lather and rinse.'.format(i + 1))
|
||||||
|
print('Done.')
|
||||||
|
|
||||||
|
user_cycles = int(input())
|
||||||
|
shampoo_instructions(user_cycles)
|
|
@ -0,0 +1,2 @@
|
||||||
|
user_input = input().split()
|
||||||
|
print(int(sum(map(int, user_input)) / len(user_input)), max(map(int, user_input)))
|
|
@ -0,0 +1,3 @@
|
||||||
|
user_input = input().split()
|
||||||
|
|
||||||
|
print(*sorted([i for i in list(map(int, user_input)) if i >= 0]), '', end='')
|
|
@ -0,0 +1,4 @@
|
||||||
|
user_input = input().split()
|
||||||
|
|
||||||
|
for element in user_input:
|
||||||
|
print(element, user_input.count(element))
|
|
@ -0,0 +1,9 @@
|
||||||
|
replacement_list = dict((k.strip(), v.strip()) for k,v in
|
||||||
|
(item.split() for item in input().split(' ')))
|
||||||
|
|
||||||
|
lab_text = input()
|
||||||
|
|
||||||
|
for element in replacement_list:
|
||||||
|
lab_text = lab_text.replace(element, replacement_list[element])
|
||||||
|
|
||||||
|
print(lab_text)
|
|
@ -0,0 +1,9 @@
|
||||||
|
user_input = input()
|
||||||
|
test_grades = list(map(int, user_input.split())) # test_grades is an integer list of test scores
|
||||||
|
|
||||||
|
|
||||||
|
sum_extra = -999 # Initialize 0 before your loop
|
||||||
|
|
||||||
|
sum_extra = sum([i for i in test_grades if i > 100]) - (len([i for i in test_grades if i > 100]) * 100)
|
||||||
|
|
||||||
|
print('Sum extra:', sum_extra)
|
|
@ -0,0 +1,10 @@
|
||||||
|
user_input = input()
|
||||||
|
hourly_temperature = user_input.split()
|
||||||
|
|
||||||
|
result = []
|
||||||
|
|
||||||
|
for temp in hourly_temperature:
|
||||||
|
result.append(temp)
|
||||||
|
result.append('->')
|
||||||
|
result.pop()
|
||||||
|
print(*result, '')
|
|
@ -0,0 +1,20 @@
|
||||||
|
user_input= input()
|
||||||
|
lines = user_input.split(',')
|
||||||
|
|
||||||
|
# This line uses a construct called a list comprehension, introduced elsewhere,
|
||||||
|
# to convert the input string into a two-dimensional list.
|
||||||
|
# Ex: 1 2, 2 4 is converted to [ [1, 2], [2, 4] ]
|
||||||
|
|
||||||
|
mult_table = [[int(num) for num in line.split()] for line in lines]
|
||||||
|
|
||||||
|
def print_array(array):
|
||||||
|
result = []
|
||||||
|
for row in array:
|
||||||
|
result = []
|
||||||
|
for column in row:
|
||||||
|
result.append(column)
|
||||||
|
result.append('|')
|
||||||
|
result.pop()
|
||||||
|
print(*result)
|
||||||
|
|
||||||
|
print_array(mult_table)
|
|
@ -0,0 +1 @@
|
||||||
|
hello,cat,man,hey,dog,boy,Hello,man,cat,woman,dog,Cat,hey,boy
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
import csv
|
||||||
|
|
||||||
|
with open(input(), newline='') as f:
|
||||||
|
reader = csv.reader(f)
|
||||||
|
data = list(reader)[0]
|
||||||
|
|
||||||
|
result = {}
|
||||||
|
|
||||||
|
for entry in data:
|
||||||
|
try:
|
||||||
|
result[entry]
|
||||||
|
|
||||||
|
result[entry] = result[entry] + 1
|
||||||
|
except KeyError:
|
||||||
|
result[entry] = 1
|
||||||
|
|
||||||
|
for key in result:
|
||||||
|
print('{0} {1}'.format(key, result[key]))
|
|
@ -0,0 +1,12 @@
|
||||||
|
20
|
||||||
|
Gunsmoke
|
||||||
|
30
|
||||||
|
The Simpsons
|
||||||
|
10
|
||||||
|
Will & Grace
|
||||||
|
14
|
||||||
|
Dallas
|
||||||
|
20
|
||||||
|
Law & Order
|
||||||
|
12
|
||||||
|
Murder, She Wrote
|
|
@ -0,0 +1,61 @@
|
||||||
|
class MutliKeyDict(dict):
|
||||||
|
"""
|
||||||
|
New Multi Key dict for this application, inherits 'dict'
|
||||||
|
"""
|
||||||
|
def __setitem__(self, key, value): # Overwrites the default __setitem__
|
||||||
|
try:
|
||||||
|
self[key]
|
||||||
|
except KeyError: # If there is a key error (like we append the same season num twice)
|
||||||
|
super(MutliKeyDict, self).__setitem__(key, []) # Make that value a list insted,
|
||||||
|
self[key].append(value) # Append that new list and save
|
||||||
|
|
||||||
|
def pharse_shows(file_location):
|
||||||
|
result = MutliKeyDict()
|
||||||
|
try:
|
||||||
|
with open(file_location) as f:
|
||||||
|
for line in f:
|
||||||
|
season = line.strip("\n")
|
||||||
|
title = next(f).strip("\n")
|
||||||
|
result[season] = title
|
||||||
|
except StopIteration:
|
||||||
|
print('Error pharsing last value, odd number of lines in file?')
|
||||||
|
return(result)
|
||||||
|
|
||||||
|
def save_output_keys(showdict):
|
||||||
|
result = '' # Set the result to a blank string
|
||||||
|
showdict = dict(sorted(showdict.items())) # Sort the dict by key
|
||||||
|
|
||||||
|
for entry in showdict: # For every dict entry in our show dict
|
||||||
|
result += '{0}: '.format(int(entry)) # Append a new line to represent that entry season count
|
||||||
|
if isinstance(showdict[entry], list): # If the entry is a list of shows
|
||||||
|
for show in showdict[entry]: # for very entry in that list of shows
|
||||||
|
result += '{0}; '.format(show) # append that show, and a ";"
|
||||||
|
result = result[:-2] + '\n' # Chop the last ";", ugly but it works. Also add carriage return
|
||||||
|
else: # If the entry is not a list
|
||||||
|
result += '{0}'.format(showdict[entry])
|
||||||
|
|
||||||
|
with open('output_keys.txt', 'w') as f:
|
||||||
|
f.write(result)
|
||||||
|
|
||||||
|
def save_output_titles(showdict):
|
||||||
|
result = [] # Set the result to a blank list
|
||||||
|
for entry in showdict: # For every dict entry in our show dict
|
||||||
|
if isinstance(showdict[entry], list): # If the entry is a list of shows
|
||||||
|
for show in showdict[entry]: # for every entry in that list of shows
|
||||||
|
result.append(show) # Append that show to our result list
|
||||||
|
else: # If the entry is not a list
|
||||||
|
result.append(showdict[entry]) # Append the result directly
|
||||||
|
|
||||||
|
result.sort() # Sort the list
|
||||||
|
|
||||||
|
resultstring = '' # Setup a new blank result string
|
||||||
|
for item in result: # Convert list to stirng, with \n
|
||||||
|
resultstring += str(item) + '\n'
|
||||||
|
|
||||||
|
with open('output_titles.txt', 'w') as f:
|
||||||
|
f.write(resultstring)
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
showdict = pharse_shows(input())
|
||||||
|
save_output_keys(showdict)
|
||||||
|
save_output_titles(showdict)
|
|
@ -0,0 +1,27 @@
|
||||||
|
class Team:
|
||||||
|
def __init__(self):
|
||||||
|
self.team_name = 'none'
|
||||||
|
self.team_wins = 0
|
||||||
|
self.team_losses = 0
|
||||||
|
self.win_percentage = 0
|
||||||
|
|
||||||
|
def get_win_percentage(self):
|
||||||
|
return self.team_wins / (self.team_wins + self.team_losses)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
|
||||||
|
team = Team()
|
||||||
|
|
||||||
|
team_name = input()
|
||||||
|
team_wins = int(input())
|
||||||
|
team_losses = int(input())
|
||||||
|
|
||||||
|
team.team_name = team_name
|
||||||
|
team.team_wins = team_wins
|
||||||
|
team.team_losses = team_losses
|
||||||
|
|
||||||
|
if team.get_win_percentage() >= 0.5:
|
||||||
|
print('Congratulations, Team', team.team_name,'has a winning average!')
|
||||||
|
else:
|
||||||
|
print('Team', team.team_name, 'has a losing average.')
|
|
@ -0,0 +1,24 @@
|
||||||
|
class PhonePlan:
|
||||||
|
# FIXME add constructor
|
||||||
|
|
||||||
|
def __init__(self, _num_mins=0, _num_messages=0):
|
||||||
|
self.num_mins = _num_mins
|
||||||
|
self.num_messages = _num_messages
|
||||||
|
|
||||||
|
def print_plan(self):
|
||||||
|
print('Mins:', self.num_mins, end=' ')
|
||||||
|
print('Messages:', self.num_messages)
|
||||||
|
|
||||||
|
|
||||||
|
my_plan = PhonePlan(int(input()), int(input()))
|
||||||
|
dads_plan = PhonePlan()
|
||||||
|
moms_plan = PhonePlan(int(input()))
|
||||||
|
|
||||||
|
print('My plan...', end=' ')
|
||||||
|
my_plan.print_plan()
|
||||||
|
|
||||||
|
print('Dad\'s plan...', end=' ')
|
||||||
|
dads_plan.print_plan()
|
||||||
|
|
||||||
|
print('Mom\'s plan...', end= ' ')
|
||||||
|
moms_plan.print_plan()
|
|
@ -0,0 +1,15 @@
|
||||||
|
class CarRecord:
|
||||||
|
def __init__(self):
|
||||||
|
self.year_made = 0
|
||||||
|
self.car_vin = ''
|
||||||
|
|
||||||
|
# FIXME add __str__()
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return'Year: {0}, VIN: {1}'.format(self.year_made, self.car_vin)
|
||||||
|
|
||||||
|
my_car = CarRecord()
|
||||||
|
my_car.year_made = int(input())
|
||||||
|
my_car.car_vin = input()
|
||||||
|
|
||||||
|
print(my_car)
|
|
@ -0,0 +1,28 @@
|
||||||
|
class Car:
|
||||||
|
def __init__(self):
|
||||||
|
self.model_year = 0
|
||||||
|
self.purchase_price = 0
|
||||||
|
self.current_value = 0
|
||||||
|
|
||||||
|
def calc_current_value(self, current_year):
|
||||||
|
depreciation_rate = 0.15
|
||||||
|
# Car depreciation formula
|
||||||
|
car_age = current_year - self.model_year
|
||||||
|
self.current_value = round(self.purchase_price * (1 - depreciation_rate) ** car_age)
|
||||||
|
|
||||||
|
def print_info(self):
|
||||||
|
return """Car's information:
|
||||||
|
Model year: {0}
|
||||||
|
Purchase price: {1}
|
||||||
|
Current value: {2}""".format(self.model_year, self.purchase_price, self.current_value)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
year = int(input())
|
||||||
|
price = int(input())
|
||||||
|
current_year = int(input())
|
||||||
|
|
||||||
|
my_car = Car()
|
||||||
|
my_car.model_year = year
|
||||||
|
my_car.purchase_price = price
|
||||||
|
my_car.calc_current_value(current_year)
|
||||||
|
print(my_car.print_info())
|
Loading…
Reference in New Issue