-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProblemaP1.py
63 lines (57 loc) · 3.05 KB
/
ProblemaP1.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# Camilo Morillo Cervantes (202015224)
# Juan Sebastián Alegría (202011282)
# Proyecto 1
import sys
import math
# Función solución
def torreTp(numPisos, numCuartos, energia, portales, pisActual, cuarActual, costosMin):
if pisActual == numPisos - 1: # Caso base: si nos encontramos en el piso final
return (numCuartos - 1 - cuarActual) * energia[pisActual]
# Caso base: no hay portales en el piso actual (dicho camino no es solución)
elif pisActual not in portales:
return math.inf
else:
# Variable iniciada en infinito que da el coste del camino con coste mínimo
minimo = math.inf
# Se verifica cada portal en el piso actual y los caminos que salen de este
for portal in portales[pisActual]:
portalKey = str(pisActual) + ',' + str(portal[0])
# Si no se recorrió el camino se recorre recursivamente
if portalKey not in costosMin:
costo = (torreTp(numPisos, numCuartos, energia, portales, portal[1], portal[2], costosMin) +
(abs(cuarActual - (portal[0]))) * energia[pisActual])
# Se guarda el camino recorrido al entrar ese portal (sin contar el costo para ir a ese portal)
costosMin[portalKey] = costo - (abs(cuarActual - (portal[0]))) * energia[pisActual]
else: # Si se recorrió el camino se saca el costo del diccionario
# El costo es el coste del camino al entrar en ese portal + el coste para moverse a dicho portal
costo = costosMin[portalKey] + (abs(cuarActual - (portal[0]))) * energia[pisActual]
if costo == 0: # Si el costo el 0 ese sera ya el costo menor ya que no hay costo negativo
return 0
if costo < minimo: # Se retorna el coste mínimo de todos estos posibles caminos
minimo = costo
return minimo
def main():
input = sys.stdin.readline
numberCases = int(input()) # Número de casos de prueba
solutions = []
for c in range(numberCases):
data = list(map(int, (input().split())))
numPisos, numCuartos, numPortales = data[0], data[1], data[2]
energia, portales = list(map(int, (input().split()))), {}
# Se consiguen los portales y se ingresan en un diccionario 'portales' cuya llave es el piso de inicio
for _ in range(numPortales):
infoPortal = input().split()
piso_i, cuarto_i, piso_f, cuarto_f = tuple(int(e) for e in infoPortal)
if piso_i - 1 not in portales:
portales[piso_i - 1] = []
portales[piso_i - 1].append([cuarto_i - 1, piso_f - 1, cuarto_f - 1])
# Se llama a la función solución con los datos anteriores
sol = torreTp(numPisos, numCuartos, energia, portales, 0, 0, {})
if sol == math.inf: # Si el coste es infinito entonces la solución no existe
solutions.append("NO EXISTE")
else: # Se agrega la solución a una lista de soluciones
solutions.append(sol)
# Output
for i in solutions:
print(i)
main()