aoc2021/5/a.py
2021-12-04 21:28:58 -08:00

40 lines
697 B
Python

from collections import defaultdict
def range_incl(a, b):
a, b = sorted([a, b])
while a <= b:
yield a
a += (1 if a <= b else -1)
with open("input.txt") as f:
lines = [i.strip() for i in f.readlines()]
points = defaultdict(lambda: 0)
for line in lines:
p1, p2 = line.split(" -> ")
x1, y1 = p1.split(",")
x2, y2 = p2.split(",")
x1 = int(x1)
y1 = int(y1)
x2 = int(x2)
y2 = int(y2)
if x1 == x2 or y1 == y2:
for xr in range_incl(x1, x2):
for yr in range_incl(y1, y2):
points[(xr, yr)] += 1
overlaps = 0
for point, hits in points.items():
if hits > 1:
overlaps += 1
print(overlaps)