Escolar Documentos
Profissional Documentos
Cultura Documentos
Programación Dinámica
Problema ejemplo
1
Problema ejemplo
1 1 2 3 4 5 6
1 0 2 1 2 2 3
3
5 2 2 0 1 1 2 2
3 1 1 0 1 1 2
2
4 2 1 1 0 2 1
6
4 5 2 2 1 2 0 1
6 3 2 2 1 1 0
Medimos longitud de caminos
EAPR - EPS - UAM 3
Problema ejemplo
1 3 1 2 3 4 5 6
1 0 8 3 9 7 9
3 4
5 5 2 8 0 5 1 9 10
17 3 3 5 0 6 4 6
2
2 4 9 1 6 0 10 9
6 5 7 9 4 10 0 2
1
4 9 6 9 10 6 9 2 0
2
Primera aproximación:
backtracking
No, no otra vez!!!! ;)
¿Cuál es el espacio de búsqueda?
1-2
1-3-2
1-3-4-2
1-3 1-3 ...
...
Cada camino desde 1-2 a fin
5-6 me da una combinación de
5-3-2-4-6 caminos desde cada nodo a
fin todos los demás.
EAPR - EPS - UAM 5
Primera aproximación :
backtracking
Funciona, pero esta solución es muy ineficiente.
Rápidamente se puede ver que, aún si el grafo es no
dirigido, el algoritmo es proporcional a n!
Para n=10, ya tengo un orden de 106 elementos que procesar...
Problema: vuelvo a calcular lo mismo una y otra vez:
1-2
1-3-2
1-3-4-2
1-3 1-3
3
Idea: recordar resultados parciales
Programación Dinámica:
4
Caminos más cortos con P.D.
Algoritmo:
Para cada nodo intermedio k (entre 1 y n)
Para cada nodo de salida i
Para cada nodo de llegada j
Veo si utilizando el nodo k existe un camino más corto que el
camino que ya existía entre i y j.
Si existe, lo apunto, si no, me quedo con el anterior
costo 0 ∞ 3 ∞ ∞ ∞ 1 3
∞ 0 5 1 ∞ ∞ 4
3
3 5 0 17 4 ∞ 5 5
17 2
∞ 1 17 0 ∞ 9 2
∞ ∞ 4 ∞ 0 2 1
6
4 9
∞ ∞ ∞ 9 2 0
EAPR - EPS - UAM 10
5
Costo de caminos más cortos
Algoritmo:
6
Caminos más cortos con P.D.
Algoritmo:
¿Cuál es el camino?
Hacemos z = camino(x,y).
Si z==y, imprimimos y //ya hemos llegado.
Sino, imprimimos camino de x a z y de z a y.