Files
aoc/2015/day09.py

78 lines
2.4 KiB
Python

# AOC Day Script Day XX
# Date : 20XX.12.XX
# Python Code
# Developer : David Bandeira
import sys,time
from itertools import permutations
from helpingFunctions import *
setSampleMode(False)
aocDay = identifyDay(sys.argv[0])
aocYear = identifyYear(sys.argv[0])
path = getPath2Data(aocDay,aocYear)
filename = getFilename2Data(aocDay)
def calcDistances(data):
trips={}
locations=[]
for dataRow in data:
trip,distance = dataRow.split(' = ')
locationA,locationB = trip.split(' to ')
locations.append(locationA)
locations.append(locationB)
locations = list(set(locations))
trips[(locationA.strip(),locationB.strip())]=int(distance.strip())
trips[(locationB.strip(),locationA.strip())]=int(distance.strip())
allTrips = list(permutations(locations))
distanceTrips={}
for run in allTrips:
allDistance=0
for i in range(len(run)-1):
allDistance += trips[(run[i],run[i+1])]
distanceTrips[run]=allDistance
return distanceTrips
def taskA (data) -> int:
global distanceTrips
gameScoreA = 0
tripSearchDistance = 0
distanceTrips = calcDistances(data)
for tripList,tripDistance in distanceTrips.items():
if tripSearchDistance == 0 or tripSearchDistance > tripDistance: tripSearchDistance = tripDistance
gameScoreA=tripSearchDistance
return gameScoreA
def taskB (data) -> int:
gameScoreB = 0
tripSearchDistance = 0
for tripList,tripDistance in distanceTrips.items():
if tripSearchDistance == 0 or tripSearchDistance < tripDistance: tripSearchDistance = tripDistance
gameScoreB=tripSearchDistance
return gameScoreB
def task(task: int,data) -> int:
score=0
if task == 1:
score = taskA(data)
elif task == 2:
score = taskB(data)
return score
def main():
showSampleMode()
try:
data = open(path+'/'+filename).read().strip().split('\n')
except:
print ('no inputfile found')
print ('please check file %s on path %s' % (filename, path))
quit()
st=time.time()
print ('Day '+aocDay+': Tasks 1: '+ str(task(1,data))+ ' executation time: ' + str(int((time.time()-st)*1000)) + 'ms')
st=time.time()
print ('Day '+aocDay+': Tasks 2: '+ str(task(2,data))+ ' executation time: ' + str(int((time.time()-st)*1000)) + 'ms')
if __name__ == "__main__":
main()