1
0
forked from tdwojak/Python2017
Python2017/labs02/task05.py

32 lines
796 B
Python
Raw Normal View History

2017-11-18 16:45:28 +01:00
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
Napisz funkcję euclidean_distance obliczającą odległość między
dwoma punktami przestrzeni trójwymiarowej. Punkty dane jako
trzyelementowe listy liczb zmiennoprzecinkowych.
2017-11-19 10:42:39 +01:00
np. odległość pomiędzy punktami (0, 0, 0) i (3, 4, 0) jest równa 5.
2017-11-18 16:45:28 +01:00
"""
2017-11-28 18:37:51 +01:00
import math
2017-11-18 16:45:28 +01:00
2017-11-28 18:38:06 +01:00
2017-11-18 16:45:28 +01:00
def euclidean_distance(x, y):
2017-11-28 18:37:51 +01:00
value=0
for i in range(3):
value+=math.pow((y[i]-x[i]),2)
return math.sqrt(value)
2017-11-18 16:45:28 +01:00
def tests(f):
inputs = [[(2.3, 4.3, -7.5), (2.3, 8.5, -7.5)]]
outputs = [4.2]
for input, output in zip(inputs, outputs):
if f(*input) != output:
return "ERROR: {}!={}".format(f(*input), output)
break
return "TESTS PASSED"
if __name__ == "__main__":
print(tests(euclidean_distance))