Documentos de Académico
Documentos de Profesional
Documentos de Cultura
ESTRUCTURAS DE DATOS
12/JULIO/2019
ALGORITMO DE PRIM
El algoritmo fue diseñado en 1930 por el matemático Voltech Jarnik y luego
por el científico computacional Robert C. Prim en 1957 y redescubierto por
Dijkstra en 1959. También se le conoce como algoritmo DJP o algoritmo de
Jarnik.
Descripción:
El algoritmo incrementa continuamente el tamaño de un árbol, comenzando
por un vértice inicial al que se le va agregando sucesivamente vértices cuya
distancia a los anteriores es mínima. Esto significa que en cada paso, las
aristas a considerar son aquellas que inciden en vértices que ya pertenecen al
árbol.
Pseudocódigo:
1. Asociar con cada vértice v del grafo un número C[v] (el mínimo
coste de conexión a v) y a un lado E[v] (el lado que provee esa
conexión de mínimo coste). Para inicializar esos valores, se
establecen todos los valores de C[v] a +∞ (o a cualquier número
más grande que el máximo tamaño de lado) y establecemos
cada E[v] a un valor "flag"(bandera) que indica que no hay
ningún lado que conecte v a vértices más cercanos.
2. Inicializar un bosque vacío F y establecer Q vértices que aún no
han sido incluidos en F (inicialmente, todos los vértices).
3. Repetir los siguientes pasos hasta que Q esté vacío:
Encontrar y eliminar un vértice v de Q teniendo el mínimo
valor de C[v].
Añadir v a F y, si E[v] no tiene el valor especial de "flag",
añadir también E[v] a F
Hacer un bucle sobre los lados vw conectando v a otros
vértices w. Para cada lado, si w todavía pertenece a Q y
vw tiene tamaño más pequeño que C[w], realizar los
siguientes pasos:
o Establecer C[w] al coste del lado vw.
o Establecer E[w] apuntando al lado vw.
4. Devolver F.
Aplicaciones:
Este algoritmo se usa normalmente para ahorrar recursos, su aplicación más
común es la implementación de cables de redes, de servidores, de postes de
luz entre otros.
Ejemplo
Situación: Implementación del cableado para el servicio de televisión
por cable en ciertos puntos de un sector de la ciudad de Puno.
Problema: Ahorrar la mayor cantidad de cable (recursos) en los puntos
estratégicos (torres de distribución) para llegar a todos los destinos
deseados.
Datos: Distancia entre torres y casas es de 10 metros (cada casa).
Planteamiento: En la figura 1 se observa la ubicación de las torres de
distribución y las viviendas.
Figura 1
En la figura 2 transformamos el conjunto de torres y viviendas en un
Grafo.
Figura 2
Figura 3