Enable Javascript in your browser and then refresh this page, for a much enhanced experience.
First solution in Clear category for Simple Areas by Rafal__Kotas
import math
def simple_areas(*args):
if(len(args)==1):
return((float(args[0])/2)*(float(args[0])/2)*math.pi)
if(len(args)==2):
return(float(args[0])*float(args[1]))
if(len(args)==3):
a=float(args[0])
b=float(args[1])
c=float(args[2])
p=float((a+b+c)/2)
return(math.sqrt(p*(p-a)*(p-b)*(p-c)))
if __name__ == '__main__':
#These "asserts" using only for self-checking and not necessary for auto-testing
def almost_equal(checked, correct, significant_digits=2):
precision = 0.1 ** significant_digits
return correct - precision < checked < correct + precision
assert almost_equal(simple_areas(3), 7.07), "Circle"
assert almost_equal(simple_areas(2, 2), 4), "Square"
assert almost_equal(simple_areas(2, 3), 6), "Rectangle"
assert almost_equal(simple_areas(3, 5, 4), 6), "Triangle"
assert almost_equal(simple_areas(1.5, 2.5, 2), 1.5), "Small triangle"
Nov. 19, 2016