Enable Javascript in your browser and then refresh this page, for a much enhanced experience.
By sides proportion + itertools.combinations solution in Clear category for Similar Triangles by Splitter
from typing import List, Tuple
from itertools import combinations
Coords = List[Tuple[int, int]]
def get_distance(v1: int, v2: int) -> float:
x1, x2, y1, y2 = v1[0], v2[0], v1[1], v2[1]
return float(((x2 - x1)**2 + (y2 - y1)**2)**(1/2))
def similar_triangles(coords_1: Coords, coords_2: Coords) -> bool:
# combinations allows not to group vertices in pairs manually.
lengths_1 = [get_distance(*side) for side in combinations(coords_1, 2)]
lengths_2 = [get_distance(*side) for side in combinations(coords_2, 2)]
ratios = {l2 / l1 for l1, l2 in zip(sorted(lengths_1), sorted(lengths_2))}
return len(ratios) == 1
if __name__ == '__main__':
print("Example:")
print(similar_triangles([(0, 0), (1, 2), (2, 0)], [(3, 0), (4, 2), (5, 0)]))
# These "asserts" are used for self-checking and not for an auto-testing
assert similar_triangles([(0, 0), (1, 2), (2, 0)], [(3, 0), (4, 2), (5, 0)]) is True, 'basic'
assert similar_triangles([(0, 0), (1, 2), (2, 0)], [(3, 0), (4, 3), (5, 0)]) is False, 'different #1'
assert similar_triangles([(0, 0), (1, 2), (2, 0)], [(2, 0), (4, 4), (6, 0)]) is True, 'scaling'
assert similar_triangles([(0, 0), (0, 3), (2, 0)], [(3, 0), (5, 3), (5, 0)]) is True, 'reflection'
assert similar_triangles([(1, 0), (1, 2), (2, 0)], [(3, 0), (5, 4), (5, 0)]) is True, 'scaling and reflection'
assert similar_triangles([(1, 0), (1, 3), (2, 0)], [(3, 0), (5, 5), (5, 0)]) is False, 'different #2'
print("Coding complete? Click 'Check' to earn cool rewards!")
Feb. 14, 2020
Comments: