advent-of-code/2023/day02.py

92 lines
2.2 KiB
Python
Executable File

#!/usr/bin/python3
"""
Jour 02 du défi Advent Of Code pour l'année 2023
"""
import os
def read_sample():
"""récupère les entrées depuis le fichier texte correspondant"""
filename = os.path.join(os.path.dirname(__file__ ), "inputs", "day02.txt")
with open(filename, 'r') as f:
sample = f.read().split('\n')
sample = [ i.split(": ")[1] for i in sample if i != '' ]
return sample
class Tirage():
def __init__(self, tirage):
self.red=0
self.green=0
self.blue=0
sets = tirage.split(", ")
for i in sets:
count, color = i.split(" ")
if color == "blue":
self.blue = int(count)
elif color == "red":
self.red = int(count)
elif color == "green":
self.green = int(count)
def __repr__(self):
return f"r{self.red}g{self.green}b{self.blue}"
def parse_tirage(tirage):
tirage.split(", ")
def parse_input(sample):
return [
[Tirage(j) for j in i.split("; ")]
for i in sample
]
def game_possible(game, red=12, green=13, blue=14):
for tirage in game:
if tirage.red > red or tirage.green > green or tirage.blue > blue:
return False
return True
def games_possible(sample, red=12, green=13, blue=14):
possible = []
for i in range(len(sample)):
if game_possible(sample[i], red=red, green=green, blue=blue):
possible.append(i+1)
return possible
def part1(sample):
"""Partie 1 du défi"""
sample = parse_input(sample)
return sum(games_possible(sample))
def minimal_set(game):
t = Tirage("green 0")
for tirage in game:
t.red = max(t.red, tirage.red)
t.green = max(t.green, tirage.green)
t.blue = max(t.blue, tirage.blue)
return t
def power(game):
t = minimal_set(game)
return t.red * t.green * t.blue
def powers(sample):
return [power(game) for game in sample]
def part2(sample):
"""Partie 2 du défi"""
sample = parse_input(sample)
return sum(powers(sample))
def main():
"""Fonction principale"""
sample = read_sample()
print(f"part1: {part1(sample)}")
print(f"part2: {part2(sample)}")
if __name__ == "__main__":
main()