Autor
|
Tema: Algoritmos para grafos (C) (Leído 11,278 veces)
|
k3r00t
Desconectado
Mensajes: 17
|
Tengo que hacer un ejercicio para mi facultad y me necesito dos algoritmos de grafos, uno es el conocido algoritmo de kruskal para el árbol recubridor mínimo, he googleado pero la verdad solo lo he visto en Java y en C++ y solo domino lenguaje C. Y el otro es un algoritmo que me calcule el camino mas corto entre un par de vértices pero no en cuanto al peso, sino en cuanto a la cantidad de aristas o arcos que recorre y la verdad de este si no he conseguido nada. De verdad se los agradecería mucho!!
|
|
|
En línea
|
|
|
|
Akai
Desconectado
Mensajes: 823
|
Y el otro es un algoritmo que me calcule el camino mas corto entre un par de vértices pero no en cuanto al peso, sino en cuanto a la cantidad de aristas o arcos que recorre y la verdad de este si no he conseguido nada. De verdad se los agradecería mucho!!
Poniendo las aritas a peso 1 debería solucionarte ese problema. Para lo otro que pides, mira el pseudocódigo de Kruskal y prográmalo tu.
|
|
|
En línea
|
|
|
|
k3r00t
Desconectado
Mensajes: 17
|
Es que no tengo ningún pseudo! solo lo he leído ya listo para compilar en C++ y en Java y ni idea de como traducirlos a C. Gracias!
|
|
|
En línea
|
|
|
|
leogtz
. . .. ... ..... ........ ............. .....................
Colaborador
Desconectado
Mensajes: 3.069
/^$/
|
Ponlo aquí en C++, a ver si se puede pasar a C sin problemas. Saludos.
|
|
|
En línea
|
|
|
|
|
k3r00t
Desconectado
Mensajes: 17
|
Claro, pero el algoritmo de Dijkstra me retornara el camino mínimo, pero yo no necesito el camino mínimo, de hecho no tengo porque tomar en cuenta los pesos, únicamente necesito el camino en el que para llegar a un Y desde X utilize el menor numero de escalas(aristas)
|
|
|
En línea
|
|
|
|
ghastlyX
Ex-Staff
Desconectado
Mensajes: 1.900
|
Kruskal si lees y entiendes cómo funciona no es para nada complicado. Mira qué hace el algoritmo y una vez lo entiendas lo podrás programar. La única parte algo más complicada es si quieres hacer eficientemente el paso de comprobar si dos nodos están unidos directa o indirectamente, que lo puedes programar con un MFSet.
Respecto al segundo problema, como ya te han dicho se reduce a un problema de caminos mínimos. Ignora los costes originales de las aristas y ponles a todas coste 1. Es evidente que el camino mínimo entre dos nodos será con estos nuevos costes aquel que use un menor número de aristas. En lo que discrepo es con la recomendación de usar Dijkstra. Cuando todas las aristas tienen el mismo coste, puede calcularse la mínima distancia de un nodo al resto usando simplemente un BFS estándar, dado que este recorre el grafo por niveles. Y BFS es más eficiente que Dijkstra.
|
|
|
En línea
|
|
|
|
k3r00t
Desconectado
Mensajes: 17
|
Kruskal si lees y entiendes cómo funciona no es para nada complicado. Mira qué hace el algoritmo y una vez lo entiendas lo podrás programar. La única parte algo más complicada es si quieres hacer eficientemente el paso de comprobar si dos nodos están unidos directa o indirectamente, que lo puedes programar con un MFSet.
Respecto al segundo problema, como ya te han dicho se reduce a un problema de caminos mínimos. Ignora los costes originales de las aristas y ponles a todas coste 1. Es evidente que el camino mínimo entre dos nodos será con estos nuevos costes aquel que use un menor número de aristas. En lo que discrepo es con la recomendación de usar Dijkstra. Cuando todas las aristas tienen el mismo coste, puede calcularse la mínima distancia de un nodo al resto usando simplemente un BFS estándar, dado que este recorre el grafo por niveles. Y BFS es más eficiente que Dijkstra.
Usar un BFS me servirá si se trata de un grafo no dirigido?
|
|
|
En línea
|
|
|
|
Valkyr
Desconectado
Mensajes: 646
Divide y vencerás
|
Sinceramente yo usaría el algoritmo de Dijkstra, porque tiene el mismo orden de complejidad que una BFS, y existen pseudocódigos que puedes traducir directamente a C.
Saludos.
|
|
|
En línea
|
|
|
|
ghastlyX
Ex-Staff
Desconectado
Mensajes: 1.900
|
Eso es falso, el orden de complejidad de Dijkstra es mayor que el de BFS y a la práctica también es más lento. Además, también hay pseudocódigos a patadas de BFS, que además es más fácil de programar que Dijkstra.
Edito: Respecto a la pregunta anterior, sirve tanto si el grafo es dirigido como no dirigido.
|
|
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
alguna dirección para bajar ejercicios de algoritmos con diagramas de flujo????
Ejercicios
|
alvaro4356
|
1
|
13,190
|
10 Enero 2007, 14:31 pm
por carlospes
|
|
|
Algoritmos para cubo de pintura
Ejercicios
|
juancho77
|
1
|
4,933
|
3 Diciembre 2008, 19:32 pm
por ghastlyX
|
|
|
Grafos
Java
|
soser
|
1
|
3,236
|
4 Noviembre 2010, 22:53 pm
por Debci
|
|
|
Aplicación en Ubuntu para cifrar con AES o algoritmos + fuertes
Criptografía
|
Gambinoh
|
4
|
7,304
|
26 Enero 2011, 20:46 pm
por DaNuK-men
|
|
|
grafos
Programación General
|
kailon
|
3
|
3,825
|
6 Junio 2011, 16:54 pm
por Valkyr
|
|