2021-01-03 20:01:38 +00:00
|
|
|
import sys
|
|
|
|
import typing
|
|
|
|
|
|
|
|
|
|
|
|
def main() -> int:
|
2021-01-03 20:13:16 +00:00
|
|
|
inputs = [int(s) for s in sys.stdin.read().split()]
|
|
|
|
for i, j in _find_2020_pairs(inputs):
|
|
|
|
print(f"pair: {i} * {j} == {i * j}")
|
|
|
|
|
|
|
|
for i, j, k in _find_2020_triplets(inputs):
|
|
|
|
print(f"triplet: {i} * {j} * {k} == {i * j * k}")
|
2021-01-03 20:01:38 +00:00
|
|
|
return 0
|
|
|
|
|
|
|
|
|
2021-01-03 20:13:16 +00:00
|
|
|
def _find_2020_pairs(
|
|
|
|
inputs: typing.List[int],
|
2021-01-04 00:44:00 +00:00
|
|
|
) -> typing.Generator[typing.Tuple[int, ...], None, None]:
|
2021-01-03 20:13:16 +00:00
|
|
|
found = []
|
|
|
|
|
|
|
|
for i, in0 in enumerate(inputs):
|
|
|
|
for j, in1 in enumerate(inputs):
|
|
|
|
if i == j:
|
|
|
|
continue
|
|
|
|
if in0 + in1 == 2020:
|
|
|
|
to_yield = tuple(sorted([in0, in1]))
|
|
|
|
if to_yield not in found:
|
|
|
|
yield to_yield
|
|
|
|
found.append(to_yield)
|
|
|
|
|
|
|
|
|
|
|
|
def _find_2020_triplets(
|
|
|
|
inputs: typing.List[int],
|
2021-01-04 00:44:00 +00:00
|
|
|
) -> typing.Generator[typing.Tuple[int, ...], None, None]:
|
2021-01-03 20:13:16 +00:00
|
|
|
found = []
|
|
|
|
|
|
|
|
for i, in0 in enumerate(inputs):
|
|
|
|
for j, in1 in enumerate(inputs):
|
|
|
|
for k, in2 in enumerate(inputs):
|
|
|
|
if i == j or i == k:
|
|
|
|
continue
|
|
|
|
if in0 + in1 + in2 == 2020:
|
|
|
|
to_yield = tuple(sorted([in0, in1, in2]))
|
|
|
|
if to_yield not in found:
|
|
|
|
yield to_yield
|
|
|
|
found.append(to_yield)
|
2021-01-03 20:01:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
sys.exit(main())
|