2024-12-03 14:28:23 +00:00
|
|
|
from collections import defaultdict
|
|
|
|
|
|
|
|
def main(infile):
|
|
|
|
points = defaultdict(int)
|
|
|
|
with open(infile) as f:
|
|
|
|
for line in f:
|
|
|
|
start, end = line.split(" -> ")
|
|
|
|
start_x, start_y = [int(x) for x in start.split(",")]
|
|
|
|
end_x, end_y = [int(x) for x in end.split(",")]
|
|
|
|
|
|
|
|
# column |
|
|
|
|
if start_x == end_x:
|
|
|
|
step = 1 if start_y < end_y else -1
|
|
|
|
for y in range(start_y, end_y + step, step):
|
|
|
|
points[(start_x, y)] = points[(start_x, y)] + 1
|
|
|
|
# line -
|
|
|
|
elif start_y == end_y:
|
|
|
|
step = 1 if start_x < end_x else -1
|
|
|
|
for x in range(start_x, end_x + step, step):
|
|
|
|
points[(x, start_y)] = points[(x, start_y)] + 1
|
|
|
|
# diagonal \
|
|
|
|
elif ((start_x < end_x and start_y > end_y)
|
|
|
|
or (start_x > end_x and start_y < end_y)):
|
|
|
|
step = 1 if start_y > end_y else -1
|
|
|
|
for dx in range(0, end_x - start_x + step, step):
|
|
|
|
points[(start_x + dx, start_y - dx)] = points[(start_x + dx, start_y + dx)] + 1
|
|
|
|
# diagonal /
|
|
|
|
elif ((start_x < end_x and start_y < end_y)
|
|
|
|
or (start_x > end_x and start_y > end_y)):
|
|
|
|
step = 1 if start_y < end_y else -1
|
|
|
|
for dx in range(0, end_x - start_x + step, step):
|
|
|
|
points[(start_x + dx, start_y + dx)] = points[(start_x + dx, start_y + dx)] + 1
|
|
|
|
|
|
|
|
res = len([x for x in points.values() if x >= 2])
|
|
|
|
print(res)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2025-01-04 14:38:12 +00:00
|
|
|
import sys
|
|
|
|
infile = sys.argv[1] if len(sys.argv) > 1 else "example.txt"
|
|
|
|
main(infile)
|