Algoritmo de Dinic
El algoritmo de Dinic es un algoritmo de Tiempo polinómico para la computación de un Flujo maximal en una red de flujo, concebida en 1970 por el científico de la computación Yefim Dinitz, israelí de origen soviético.[1] El algoritmo es ejecutado en un tiempo de y está basado en el Algoritmo de Edmonds-Karp, el cual a su vez se ejecuta en un tiempo , y utiliza trayectorias de aumento más cortas. La introducción de los conceptos nivel de grafo y bloqueo de flujo es lo que define el rendimiento del algoritmo de Dinic.
Definición
editarSe tiene el grafo que será una red de flujo con es la capacidad y el flujo del arco .
- La capacidad residual es un mapeo definido como,
- Si ,
- de otra manera.
- Si ,
- El grafo residual es el grafo , donde
- .
- La trayectoria de aumento es una ruta en el grafo residual .
- Se define como la longitud del camino más corto desde hasta en .Entonces el nivel del grafo de es el grafo , donde
- .
- El bloqueo del flujo es un flujo de manera tal que el grafo con no tiene ninguna ruta .
Algoritmo
editarAlgoritmo de Dinic
- Entrada: Una red .
- Salida: Un flujo de valor maximizado.
- Se tiene para cada .
- Construir desde de . Si , detener y retornar el resultado .
- Encontrar un bloqueo de flujo en .
- Aumentar el flujo by y volver al paso 2.
Análisis
editarSe puede demostrar que el número de arcos en cada bloqueo de flujo, es incrementado en al menos 1 unidad cada vez, y por lo tanto hay al menos bloqueos de flujo en el algoritmo, donde es el número de vértices en la red. El nivel del grafo puede ser construido por búsqueda en anchura en un tiempo de y un bloqueo de flujo en cada nivel del grafo puede ser encontrado en un tiempo de . Por lo tanto, el tiempo del algoritmo de Dinic es de .
Usando una estructura de datos llamada árboles dinámicos, el tiempo de ejecución para encontrar un bloqueo de flujo en cada fase puede ser reducido a y por lo tanto el tiempo de ejecución del algoritmo de Dinic puede ser reducido a .
Casos Especiales
editarEn redes con capacidades de unidad, el tiempo de ejecución es mucho mayor. Cada bloqueo de flujo puede ser encontrado en un tiempo de , y es demostrable que el número de fases no excedan y . En estos casos el algoritmo se ejecuta en un tiempo de .
En las redes surgidas durante la solución del problema de apareamiento, el número de fases está limitado por ,lo cual resulta en un limitado tiempo de . El algoritmo resultante a raíz de esto es conocido como algoritmo Hopcroft–Karp. De manera más general, este límite se mantiene para cualquier red unitaria — un tipo de red en la que cada vértice, excepto para los vértices fuente y sumidero, o bien tienen un único arco de capacidad, o un único arco con salida, y todas las demás capacidades son valores enteros arbitrarios.[2]
Ejemplo
editarEsta es una simulación del algoritmo de Dinic. En el nivel del grafo , los vértices marcados en rojo son los valores . Las rutas en azul forman el bloqueo de flujo.
Historia
editarEl algoritmo de Dinic fue publicado en 1970 por el ex ruso científico de la computación Yefim (Chaim) A. Dinitz , quien hoy es miembro del departamento de Ciencias de la Computación en Universidad Ben-Gurión del Néguev (Israel). Dicha publicación se realizó antes que la del algoritmo de Edmonds-Karp, el cual fue publicado en 1972, pero fue descubierta antes. Ambos demostraron cada uno por su cuenta, que en el algoritmo de Ford-Fulkerson, si cada ruta de aumento es la más corta, el largo de la ruta de aumento es no decreciente.
Véase también
editarReferencias
editar- ↑ Yefim Dinitz (1970). «Algorithm for solution of a problem of maximum flow in a network with power estimation». Doklady Akademii nauk SSSR 11: 1277-1280. Archivado desde el original el 22 de agosto de 2016. Consultado el 22 de abril de 2012.
- ↑ Tarjan, 1983, p. 102.
- Yefim Dinitz (2006). «Dinitz' Algorithm: The Original Version and Even's Version». En Oded Goldreich, Arnold L. Rosenberg, and Alan L. Selman, ed. Theoretical Computer Science: Essays in Memory of Shimon Even. Springer. pp. 218-240. ISBN 978-3540328803. Archivado desde el original el 20 de agosto de 2016. Consultado el 22 de abril de 2012.
- Tarjan, R. E. (1983). Data structures and network algorithms.
- B. H. Korte, Jens Vygen (2008). «8.4 Blocking Flows and Fujishige's Algorithm». Combinatorial Optimization: Theory and Algorithms (Algorithms and Combinatorics, 21). Springer Berlin Heidelberg. pp. 174–176. ISBN 978-3-540-71844-4.