2023 day 6 part 2 solved

master
kwout 1 year ago
parent 2aff65363f
commit 150bcd5f84
  1. 16
      2023/6.py

@ -1,8 +1,12 @@
from math import pow, ceil, floor from math import pow, ceil, floor
lines = [l.split() for l in open("input.txt", 'r').read().splitlines()] lines = open("input.txt", 'r').read().splitlines()
races = [(int(lines[0][i]), int(lines[1][i])) for i in range(1,len(lines[0]))] cols = [l.split() for l in lines]
races = [(int(cols[0][i]), int(cols[1][i])) for i in range(1,len(cols[0]))]
#[(time, record)] #[(time, record)]
realRace = (int(lines[0].split(": ")[1].replace(" ","")), int(lines[1].split(": ")[1].replace(" ","")))
print(realRace)
#d = t * v #d = t * v
#charge + t = time #charge + t = time
@ -13,12 +17,16 @@ races = [(int(lines[0][i]), int(lines[1][i])) for i in range(1,len(lines[0]))]
summa = 1 summa = 1
for race in races: def findWays(race):
a = -1 a = -1
b = race[0] b = race[0]
c = -race[1] c = -race[1]
rangeStart = floor((-b + pow((pow(b,2)-(4*a*c)),0.5)) / (2*a)) + 1 rangeStart = floor((-b + pow((pow(b,2)-(4*a*c)),0.5)) / (2*a)) + 1
rangeEnd = ceil((-b - pow((pow(b,2)-(4*a*c)),0.5)) / (2*a)) - 1 rangeEnd = ceil((-b - pow((pow(b,2)-(4*a*c)),0.5)) / (2*a)) - 1
summa *= (rangeEnd-rangeStart+1) return rangeEnd-rangeStart+1
for r in races:
summa *= findWays(r)
print(summa) print(summa)
print(findWays(realRace))
Loading…
Cancel
Save