Day 2 Part 2
parent
6f4c8c010f
commit
ac6abe0ced
|
|
@ -1,3 +1,6 @@
|
||||||
|
from typing import Generator
|
||||||
|
|
||||||
|
|
||||||
def parse_input() -> list[tuple[int, int]]:
|
def parse_input() -> list[tuple[int, int]]:
|
||||||
with open("input.txt", "r") as f:
|
with open("input.txt", "r") as f:
|
||||||
output = []
|
output = []
|
||||||
|
|
@ -10,23 +13,44 @@ def parse_input() -> list[tuple[int, int]]:
|
||||||
def part_1():
|
def part_1():
|
||||||
total = 0
|
total = 0
|
||||||
for n1, n2 in parse_input():
|
for n1, n2 in parse_input():
|
||||||
print(n1, n2, end=": ")
|
|
||||||
for n in range(n1, n2 + 1):
|
for n in range(n1, n2 + 1):
|
||||||
n_str = str(n)
|
n_str = str(n)
|
||||||
middle = len(n_str) // 2
|
middle = len(n_str) // 2
|
||||||
if len(n_str) % 2 == 0 and len(set(n_str)) == 1:
|
if len(n_str) % 2 == 0 and len(set(n_str)) == 1:
|
||||||
print(n, end=", ")
|
|
||||||
total += n
|
total += n
|
||||||
elif n_str[:middle] == n_str[middle:]:
|
elif n_str[:middle] == n_str[middle:]:
|
||||||
total += n
|
total += n
|
||||||
print(n, end=", ")
|
print(total)
|
||||||
print()
|
|
||||||
|
|
||||||
|
def wrap(s: str, n: int) -> Generator[str]:
|
||||||
|
while s:
|
||||||
|
yield s[:n]
|
||||||
|
s = s[n:]
|
||||||
|
|
||||||
|
|
||||||
|
def part_2():
|
||||||
|
total = 0
|
||||||
|
for n1, n2 in parse_input():
|
||||||
|
for n in range(n1, n2 + 1):
|
||||||
|
n_str = str(n)
|
||||||
|
len_n = len(n_str)
|
||||||
|
middle = len_n // 2
|
||||||
|
for div in range(1, middle + 1):
|
||||||
|
if len_n % div != 0:
|
||||||
|
continue
|
||||||
|
|
||||||
|
if len(set(wrap(n_str, div))) == 1:
|
||||||
|
total += n
|
||||||
|
break
|
||||||
print(total)
|
print(total)
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
print("Part 1:")
|
print("Part 1:")
|
||||||
part_1()
|
part_1()
|
||||||
|
print("Part 2:")
|
||||||
|
part_2()
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue