berkeley_temp = 18
miami_temp = 32
def c_to_f(temp):
return (9 / 5) * temp + 32
c_to_f(0)
c_to_f(berkeley_temp)
def seconds_converter(seconds_in):
seconds_in_minute = 60
seconds_in_hour = 60 * 60
# First, determine the number of whole hours
# e.g. if s = 5152, this is 1
hours = seconds_in // seconds_in_hour
# Compute the number of "seconds left over"
seconds_left = seconds_in % seconds_in_hour
# Now, determine the number of whole minutes
# e.g. if seconds_left = 1850, this is 30
minutes = seconds_left // seconds_in_minute
# The number of seconds left over now is the number of seconds we should print
seconds = seconds_left % seconds_in_minute
print('Hours: ', hours)
print('Minutes: ', minutes)
print('Seconds: ', seconds)
seconds_converter(5400)
seconds_converter(8182)
Suppose we have a list of temperatures of cities around the world.
# Run this cell, don't worry about the code.
from datascience import *
table = Table.read_table('data/africa-temperatures.csv')
c_temps = list(table.apply(lambda s: float(s[:s.index('(')]), 'Year'))
c_temps
Remember, we already defined c_to_f
, which takes a temperature in Celsius to a temperature in Fahrenheit.
How do we convert the 3rd temperature to Fahrenheit? The 9th temperature? The very last temperature in the list?
def c_to_f(temp):
return (9 / 5) * temp + 32
c_temps[3]
c_to_f(c_temps[3])
c_to_f(c_temps[9])
last_in_f = ...
Quick recap: while loops allow us to repeat a code block as long as some boolean expression is true.
# Don't do this
print('1 is not even')
print('2 is even')
print('3 is not even')
print('4 is even')
print('5 is not even')
print('6 is even')
print('7 is not even')
print('8 is even')
print('9 is not even')
print('10 is even')
# Instead, do this
n = 1
while n <= 10:
if n % 2 == 0:
print(str(n) + ' is even')
else:
print(str(n) + ' is not even')
n = n + 1
Back to the question at hand: how do we make a new list with all temperatures converted to Fahrenheit?
def convert_list(c_temps):
f_temps = []
i = 0
while i < len(c_temps):
# Get the ith C temp
c_temp = c_temps[i]
# Convert it to F
f_temp = c_to_f(c_temp)
# Add it to the output list
f_temps.append(f_temp)
# Increment i
i += 1
return f_temps
convert_list([32, 19, 23])
convert_list(c_temps)
Task: Given a list of prices of a stock on a single day, return a string describing whether the stock increased, stayed the same, or decreased from its starting price.
def daily_change(prices):
first = prices[0]
last = prices[-1]
if first > last:
return 'decrease'
elif first == last:
return 'none'
else:
return 'increase'
# Returns 'increase', since 1 < 4
daily_change([1, 2, 2.5, 3, 3.5, 4])
# Returns 'none', since 3 = 3
daily_change([3, 9, 3])
# Return 'decrease', since 5 > 2
daily_change([5, 4, 3, 4, 5, 4, 3, 2, 2])
Task: Given a list of prices of a stock on a single day, return True
if the stock was strictly increasing, and False
otherwise. A list of numbers is strictly increasing if each one is larger than the previous.
def strictly_increasing(prices):
i = 0
while i < len(prices) - 1:
if ...:
return False
i += 1
return True
def next_day(day):
week = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']
curr = week.index(day)
return week[(curr + 1) % 7]
next_day('Wednesday')
next_day('Saturday')
Given the side lengths of a triangle as a list (sides
), return:
'equilateral'
if all three side lengths are equal'isoceles'
if exactly two of the three side lengths are equal'scalene'
if all three side lengths are differentIf any of the side lengths are less than or equal to 0, return 'invalid'
.
def triangle_type(sides):
...
# Uncomment this to check your implementation – the result should be 'equilateral'
# triangle_type([6, 6, 6])
# Uncomment this to check your implementation – the result should be 'isoceles'
# triangle_type([5, 6, 5])
# Uncomment this to check your implementation – the result should be 'scalene'
# triangle_type([5, 6, 7])
# Uncomment this to check your implementation – the result should be 'invalid'
# triangle_type([5, 6, 0])
def triangle_type(sides):
if sides[0] <= 0 or sides[1] <= 0 or sides[2] <= 0:
return 'invalid'
if sides[0] == sides[1] == sides[2]:
return 'equilateral'
elif (sides[0] == sides[1]) or (sides[1] == sides[2]) or (sides[0] == sides[2]):
return 'isoceles'
else:
return 'scalene'