SlideShare a Scribd company logo
TEORÍA DE GRAFOS
UNIDAD 3
TEORÍA DE GRAFOS
• LOS GRAFOS SON ESTRUCTURAS DISCRETAS QUE
APARECEN UBICUAMENTE EN CADA DISCIPLINA DONDE SE
REQUIERE MODELAR ALGO.
• EN GENERAL LOS GRAFOS SON MAPAS CONCEPTUALES QUE
AYUDAN A REPRESENTAR EL CONOCIMIENTO.
• LOS GRAFOS TIENE MUCHAS APLICACIONES EN PROBLEMAS
DE INGENIERÍA, COMPUTACIÓN, BIOLOGÍA, FÍSICA,
URBANISMO, COMUNICACIONES, ECONOMÍA, REDES
SOCIALES, ENTRE MUCHAS OTRAS.
2
TEORÍA DE GRAFOS (CONT.)
• APLICACIONES DE LOS GRAFOS:
• INTERNET Y LOS PROTOCOLOS DE COMUNICACIONES
(TCP/IP, SMTP, FTP, ROUTERS, ETC.)
• DISEÑO DE REDES DE COMUNICACIONES Y TRANSPORTE
(REDES COMPUTACIONALES, CARRETERAS, AGUAS,
ELECTRICIDAD, TELECOMUNICACIONES, AVIACIÓN,
SATÉLITES, AERO-ESPACIAL, FLOTAS DE VEHÍCULOS, ETC.)
• ESTRUCTURA DE DATOS
• ALGORITMOS COMPUTACIONALES
• NAVEGADOR GPS (GOOGLE MAPS)
3
TEORÍA DE GRAFOS (CONT.)
• APLICACIONES DE LOS GRAFOS:
• ECONOMÍA (BOLSA, TRANSACCIONES ECONÓMICAS,
MODELOS DE MERCADO, ETC.)
• EMPRESA (LOCALIZACIÓN, ESTRATEGIA, TEORÍA DE
JUEGOS, ANÁLISIS DE LA COMPETENCIA, LOGÍSTICA, CRM,
ERP, MRP, SCHEDULING, ESQUEMA ORGANIZACIONAL,
ETC.)
• REDES SOCIALES (FACEBOOK, SKYPE, MSN)
• POLÍTICA Y MARKETING
• SEGURIDAD Y PREVENCIÓN DEL TERRORISMO
• INTELIGENCIA MILITAR
4
TEORÍA DE GRAFOS (CONT.)
• APLICACIONES DE LOS GRAFOS:
• OCIO (VIDEO JUEGOS, SIMULACIÓN E IA)
• DOMÓTICA, ROBÓTICA, AUTOMATIZACIÓN, CONTROL Y
GESTIÓN DE REDES, ETC.
• LA WEB (ES UN GRAFO CUYA ESTRUCTURA CAMBIA CADA
SEGUNDO)
• WEB SEMÁNTICA
• INVESTIGACIÓN MÉDICA, BIOGENÉTICA (SECUENCIACIÓN
ADN)
• BIOLOGÍA, MEDIO-AMBIENTE, CAMBIO CLIMÁTICO
• ÁRBOLES GENEALÓGICOS
5
PROPIEDADES DE LOS GRAFOS
• ADYACENCIA. DOS ARISTAS SON ADYACENTES SI TIENEN UN
VÉRTICE EN COMÚN, Y DOS VÉRTICES SON ADYACENTES SI
UNA ARISTA LOS UNE.
• INCIDENCIA. UNA ARISTA ES INCIDENTE A UN VÉRTICE SI ÉSTA
LO UNE A OTRO.
• PONDERACIÓN. CORRESPONDE A UNA FUNCIÓN QUE ASOCIA A
CADA ARISTA UN VALOR (COSTO, PESO, LONGITUD, ETC.),
PARA AUMENTAR LA EXPRESIVIDAD DEL MODELO.
• ETIQUETADO. DISTINCIÓN QUE SE HACE A LOS VÉRTICES Y/O
ARISTAS MEDIANTE UNA MARCA QUE LOS HACE
UNÍVOCAMENTE DISTINGUIBLES DEL RESTO.
6
¿QUÉ ES UN GRAFO?
• UN GRAFO G CONSISTE EN UN CONJUNTO NO VACÍO DE
VÉRTICES O NODOS V Y UN CONJUNTO DE ARCOS O ARISTAS E
 G = (V,E).
• GRAFO DEL GRIEGO GRAFOS: DIBUJO, IMAGEN.
• CADA E Є E TIENE UN PAR (V1,V2) Є V X V ASOCIADO; ES DECIR,
E CONECTA V1 CON V2.
• EL ORDEN DEL GRAFO G A SU NÚMERO DE VÉRTICES  G = |V|.
• EL GRADO DE UN VÉRTICE O NODO V Є V ES IGUAL AL NÚMERO
DE ARCOS O ARISTAS QUE LO TIENEN COMO EXTREMO.
7
¿QUÉ ES UN GRAFO? (CONT.)
• VÉRTICES (NODOS). ELEMENTOS (OBJETOS) QUE FORMAN UN
GRAFO. CADA UNO LLEVA ASOCIADA UN GRADO
CARACTERÍSTICO SEGÚN LA SITUACIÓN, QUE SE CORRESPONDE
CON LA CANTIDAD DE ARCOS O ARISTAS QUE CONFLUYEN EN
DICHO VÉRTICE.
• ARCOS O ARISTAS. RELACIONES ENTRE LOS ELEMENTOS QUE
FORMAN EL GRAFO. EXISTEN LOS SIGUIENTES TIPOS:
• RAMAS. ARCO O ARISTA QUE UNEN UN VÉRTICE CON
OTRO.
• PARALELAS (MÚLTIPLES). ARCOS O ARISTAS
CONJUNTAS SI EL VÉRTICE INICIAL Y FINAL SON EL
MISMO.
8
¿QUÉ ES UN GRAFO? (CONT.)
• UN GRAFO PONDERADO G = (V,E,W) ES UN GRAFO EN EL QUE A
CADA ARCO O ARISTA 𝑒 ∈ 𝐸 SE LE ASOCIA UN PESO 𝑤 𝑒 ∈ ℝ.
• EN UN GRAFO DIRIGIDO, UN VÉRTICES ES ADYACENTE A OTRO
SI ESTÁN CONECTADOS POR UN ARCO (COLA → CABEZA),
DONDE EL VÉRTICE CABEZA ES ADYACENTE AL VÉRTICE COLA.
• EN TAL CASO, EL VÉRTICES COLA ES INCIDENTE AL
VÉRTICE CABEZA.
• EN UN GRAFO NO DIRIGIDO, DOS VÉRTICES
SON ADYACENTES SI ESTÁN CONECTADOS POR UNA ARISTA.
• EN TAL CASO, CADA UNO DE ESTOS VÉRTICES
ES INCIDENTE A DICHA ARISTA. 9
GRAFO BIPARTITO
• UN GRAFO BIPARTITO (O BIPARTIDO) ES UN GRAFO SIMPLE
G = (N,E) CUYOS VÉRTICES SE PUEDEN SEPARAR EN DOS
CONJUNTOS DISJUNTOS U Y V, DE MANERA QUE LAS
ARISTAS SÓLO PUEDEN CONECTAR VÉRTICES DE UN
CONJUNTO CON VÉRTICES DEL OTRO.
• LOS GRAFOS BIPARTITOS SUELEN REPRESENTARSE
GRÁFICAMENTE CON DOS COLUMNAS (O FILAS) DE
VÉRTICES Y LAS ARISTAS UNIENDO VÉRTICES DE
COLUMNAS (O FILAS) DIFERENTES.
10
GRAFO BIPARTITO
• LOS DOS CONJUNTOS U Y V PUEDEN SER PENSADOS COMO UN
COLOREO DEL GRAFO CON DOS COLORES.
• UN GRAFO SIMPLE ES BIPARTITO SI Y SOLO SI ES POSIBLE
ASIGNAR UNO DE DOS COLORES DIFERENTES A CADA
VÉRTICE DEL GRAFO, DE TAL FORMA QUE NINGÚN PAR
(U,V) DE VÉRTICES ADYACENTES RECIBE EL MISMO COLOR.
• UN GRAFO BIPARTITO CON LA PARTICIÓN DE LOS VÉRTICES EN U Y V
SUELE DENOTARSE G = (U, V, E).
• SI |U| =|V|, ESTO ES, SI LOS DOS SUBCONJUNTOS TIENE LA
MISMA CANTIDAD DE ELEMENTOS O CARDINALIDAD,
DECIMOS QUE EL GRAFO BIPARTITO G ES BALANCEADO.
11
GRAFO BIPARTITO COMPLETO
12
GRAFO BIPARTITO COMPLETO
13
ALGORITMOS DE GRAFOS
DIRIGIDOS
• ALGORITMOS DE DETERMINACIÓN DE LOS CAMINOS MÁS
CORTOS:
• ALGORITMO DE DIJKSTRA.
• ALGORITMO DE FLOYD-WARSHALL.
• ALGORITMOS DE RECORRIDO O BÚSQUEDA:
• ALGORITMO DE BÚSQUEDA EN ANCHURA O
AMPLITUD.
• ALGORITMO DE BÚSQUEDA EN PROFUNDIDAD.
• BOSQUES ABARCADORES. 14
ALGORITMOS DE GRAFOS
DIRIGIDOS –
ALGORITMO DE DIJKSTRA
• EL ALGORITMO DE DIJKSTRA, TAMBIÉN LLAMADO
ALGORITMO DE CAMINOS MÍNIMOS, ES UN ALGORITMO
PARA LA DETERMINACIÓN DEL CAMINO MÁS CORTO DADO
UN VÉRTICE ORIGEN AL RESTO DE VÉRTICES EN UN GRAFO
DIRIGIDO Y CON PESOS EN CADA ARCO.
• SU NOMBRE SE REFIERE A EDSGER DIJKSTRA, QUIEN LO
DESCRIBIÓ POR PRIMERA VEZ EN 1959.
15
ALGORITMOS DE GRAFOS
DIRIGIDOS –
ALGORITMO DE DIJKSTRA (CONT.)
• LA IDEA SUBYACENTE EN ESTE ALGORITMO CONSISTE EN IR
EXPLORANDO TODOS LOS CAMINOS MÁS CORTOS QUE
PARTEN DEL VÉRTICE ORIGEN Y QUE LLEVAN A TODOS LOS
DEMÁS VÉRTICES.
• CUANDO SE OBTIENE EL CAMINO MÁS CORTO DESDE EL
VÉRTICE ORIGEN, AL RESTO DE VÉRTICES QUE COMPONEN
EL GRAFO, EL ALGORITMO SE DETIENE.
• EL ALGORITMO ES UNA ESPECIALIZACIÓN DE LA BÚSQUEDA
DE COSTO UNIFORME, Y COMO TAL, NO FUNCIONA EN
GRAFOS CON ARISTAS DE COSTO NEGATIVO.
16
ALGORITMOS DE GRAFOS
DIRIGIDOS –
ALGORITMO DE DIJKSTRA (CONT.)
• DESCRIPCIÓN DETALLADA:
• SEA G=(V,E) UN GRAFO DIRIGIDO Y ETIQUETADO.
• SEAN LOS VÉRTICES A  V Y Z  V; A ES EL VÉRTICE DE
ORIGEN Y Z EL VÉRTICE DE DESTINO.
• SEA UN CONJUNTO C  V, QUE CONTIENE LOS VÉRTICES
DE V CUYO CAMINO MÁS CORTO DESDE A TODAVÍA NO
SE CONOCE.
• SEA UN VECTOR D, CON TANTAS DIMENSIONES COMO
ELEMENTOS TIENE V, Y QUE “GUARDA” LAS DISTANCIAS
ENTRE A Y CADA UNO DE LOS VÉRTICES DE V.
• SEA, FINALMENTE, OTRO VECTOR, P, CON LAS MISMAS
DIMENSIONES QUE D, Y QUE CONSERVA LA
INFORMACIÓN SOBRE QUÉ VÉRTICE PRECEDE A CADA
UNO DE LOS VÉRTICES EN EL CAMINO.
17
ALGORITMOS DE GRAFOS
DIRIGIDOS –
ALGORITMO DE DIJKSTRA (CONT.)
• DESCRIPCIÓN DETALLADA:
• EL ALGORITMO PARA DETERMINAR EL CAMINO DE
LONGITUD MÍNIMA ENTRE LOS VÉRTICES A Y Z ES: C 
V.
1. PARA TODO VÉRTICE I  C, I ≠ A, SE ESTABLECE DI 
∞ ; DA  0.
2. PARA TODO VÉRTICE I  C SE ESTABLECE PI = A.
3. SE OBTIENE EL VÉRTICE S  C TAL QUE NO EXISTE
OTRO VÉRTICE W ∈ C TAL QUE DW < DS.
• SI S = Z ENTONCES SE HA TERMINADO EL
ALGORITMO.
4. SE ELIMINA DE C EL VÉRTICE S: C  C−{S}.
5. PARA CADA ARISTA E ∈ E DE LONGITUD L, QUE UNE
EL VÉRTICE S CON ALGÚN OTRO VÉRTICE T ∈ C,
• SI L + DS < DT, ENTONCES:
• SE ESTABLECE DT  L + DS.
• SE ESTABLECE PT  S.
6. SE REGRESA AL PASO 4.
18
ALGORITMOS DE GRAFOS
DIRIGIDOS –
ALGORITMO DE DIJKSTRA (CONT.)
• AL TERMINAR ESTE ALGORITMO, EN DZ ESTARÁ GUARDADA LA
DISTANCIA MÍNIMA ENTRE A Y Z.
• POR OTRO LADO, MEDIANTE EL VECTOR P SE PUEDE OBTENER
EL CAMINO MÍNIMO: EN PZ ESTARÁ Y, EL VÉRTICE QUE
PRECEDE A Z EN EL CAMINO MÍNIMO; EN PY ESTARÁ EL QUE
PRECEDE A Y, Y ASÍ SUCESIVAMENTE, HASTA LLEGAR A
ESTADO DE ENLACE.
• APLICACIÓN WEB DEL ALGORITMO:
• HTTP://NEO.LCC.UMA.ES/EVIRTUAL/CDD/APPLETS/DIS
TANCIA%20CORTA/EXAMPLE2.HTML.
19
ALGORITMOS DE GRAFOS
DIRIGIDOS –
ALGORITMO DE DIJKSTRA (CONT.)
• EJEMPLO:
• ENCONTRAR LOS CAMINOS MÁS CORTOS ENTRE
EL VÉRTICE 1 Y TODOS LOS DEMÁS DEL SIGUIENTE
GRAFO DIRIGIDO.
20

More Related Content

What's hot

Estructuras Selectivas
Estructuras Selectivas Estructuras Selectivas
Estructuras Selectivas
Jhonny Zuñiga
 
Protocolos y funcionalidades de la capa de aplicacion
Protocolos y funcionalidades de la capa de aplicacionProtocolos y funcionalidades de la capa de aplicacion
Protocolos y funcionalidades de la capa de aplicacion
Fernando Illescas Peña
 
Protección de datos
Protección de datosProtección de datos
Protección de datos
Dario
 
80286 80386-80486
80286 80386-8048680286 80386-80486
80286 80386-80486
Jorge Luis Tinoco
 
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
Connections Systems
 
Protocolos de las capas sesion,presentacion y aplicacion
Protocolos de las capas sesion,presentacion y aplicacionProtocolos de las capas sesion,presentacion y aplicacion
Protocolos de las capas sesion,presentacion y aplicacion
Eduardo J Onofre
 
Unidad 5 Estructuras algoritmicas
Unidad 5 Estructuras algoritmicasUnidad 5 Estructuras algoritmicas
Unidad 5 Estructuras algoritmicas
Carlos M. Sandoval
 
PROGRAMACION CONCURRENTE
PROGRAMACION CONCURRENTEPROGRAMACION CONCURRENTE
PROGRAMACION CONCURRENTE
Percy Javier Flores Mamani
 
Direccionamiento ip-y-subredes-ejercicios-resueltos-1194346207489436-2
Direccionamiento ip-y-subredes-ejercicios-resueltos-1194346207489436-2Direccionamiento ip-y-subredes-ejercicios-resueltos-1194346207489436-2
Direccionamiento ip-y-subredes-ejercicios-resueltos-1194346207489436-2
Isabel Jiménez Carranza
 
Presentación de Memorias
Presentación de MemoriasPresentación de Memorias
Presentación de Memorias
Enrique Cabello
 
Sistemas operativos para redes
Sistemas operativos para redesSistemas operativos para redes
Sistemas operativos para redes
Ivan Mejia Martinez
 
Normalización de Base de Datos
Normalización de Base de DatosNormalización de Base de Datos
Normalización de Base de Datos
Vannesa Salazar
 
Importancia de la construcción de redes de información
Importancia de  la construcción de redes de informaciónImportancia de  la construcción de redes de información
Importancia de la construcción de redes de información
Elamigojiumber
 
control de concurrencia
control de concurrenciacontrol de concurrencia
control de concurrencia
Jose Guadalupe Couoh Dzul
 
Mapa conceptual procesador.jpg
Mapa conceptual procesador.jpgMapa conceptual procesador.jpg
Mapa conceptual procesador.jpgYesid Calixto
 
Distribución y fragmentación de datos
Distribución y fragmentación  de datosDistribución y fragmentación  de datos
Distribución y fragmentación de datos
José Mendoza
 
Entidad Relación Banco
Entidad Relación BancoEntidad Relación Banco
Entidad Relación Banco
Miguel Pustela Jara
 
ficha tecnica pc
ficha tecnica pcficha tecnica pc
ficha tecnica pc
Alberto Alzate
 
Capa de enlace de datos
Capa de enlace de datosCapa de enlace de datos
Capa de enlace de datos
Jorge Arroyo
 
Fundamentos de Redes. Tema 3 - La capa de Aplicación
Fundamentos de Redes. Tema 3 - La capa de AplicaciónFundamentos de Redes. Tema 3 - La capa de Aplicación
Fundamentos de Redes. Tema 3 - La capa de Aplicación
Miguel Ángel Martín Tardío
 

What's hot (20)

Estructuras Selectivas
Estructuras Selectivas Estructuras Selectivas
Estructuras Selectivas
 
Protocolos y funcionalidades de la capa de aplicacion
Protocolos y funcionalidades de la capa de aplicacionProtocolos y funcionalidades de la capa de aplicacion
Protocolos y funcionalidades de la capa de aplicacion
 
Protección de datos
Protección de datosProtección de datos
Protección de datos
 
80286 80386-80486
80286 80386-8048680286 80386-80486
80286 80386-80486
 
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
 
Protocolos de las capas sesion,presentacion y aplicacion
Protocolos de las capas sesion,presentacion y aplicacionProtocolos de las capas sesion,presentacion y aplicacion
Protocolos de las capas sesion,presentacion y aplicacion
 
Unidad 5 Estructuras algoritmicas
Unidad 5 Estructuras algoritmicasUnidad 5 Estructuras algoritmicas
Unidad 5 Estructuras algoritmicas
 
PROGRAMACION CONCURRENTE
PROGRAMACION CONCURRENTEPROGRAMACION CONCURRENTE
PROGRAMACION CONCURRENTE
 
Direccionamiento ip-y-subredes-ejercicios-resueltos-1194346207489436-2
Direccionamiento ip-y-subredes-ejercicios-resueltos-1194346207489436-2Direccionamiento ip-y-subredes-ejercicios-resueltos-1194346207489436-2
Direccionamiento ip-y-subredes-ejercicios-resueltos-1194346207489436-2
 
Presentación de Memorias
Presentación de MemoriasPresentación de Memorias
Presentación de Memorias
 
Sistemas operativos para redes
Sistemas operativos para redesSistemas operativos para redes
Sistemas operativos para redes
 
Normalización de Base de Datos
Normalización de Base de DatosNormalización de Base de Datos
Normalización de Base de Datos
 
Importancia de la construcción de redes de información
Importancia de  la construcción de redes de informaciónImportancia de  la construcción de redes de información
Importancia de la construcción de redes de información
 
control de concurrencia
control de concurrenciacontrol de concurrencia
control de concurrencia
 
Mapa conceptual procesador.jpg
Mapa conceptual procesador.jpgMapa conceptual procesador.jpg
Mapa conceptual procesador.jpg
 
Distribución y fragmentación de datos
Distribución y fragmentación  de datosDistribución y fragmentación  de datos
Distribución y fragmentación de datos
 
Entidad Relación Banco
Entidad Relación BancoEntidad Relación Banco
Entidad Relación Banco
 
ficha tecnica pc
ficha tecnica pcficha tecnica pc
ficha tecnica pc
 
Capa de enlace de datos
Capa de enlace de datosCapa de enlace de datos
Capa de enlace de datos
 
Fundamentos de Redes. Tema 3 - La capa de Aplicación
Fundamentos de Redes. Tema 3 - La capa de AplicaciónFundamentos de Redes. Tema 3 - La capa de Aplicación
Fundamentos de Redes. Tema 3 - La capa de Aplicación
 

More from Fernando Solis

Concepto y definición de tipos de Datos Abstractos en c++.pptx
Concepto y definición de tipos de Datos Abstractos en c++.pptxConcepto y definición de tipos de Datos Abstractos en c++.pptx
Concepto y definición de tipos de Datos Abstractos en c++.pptx
Fernando Solis
 
AULA INVERTIDA.pdf
AULA INVERTIDA.pdfAULA INVERTIDA.pdf
AULA INVERTIDA.pdf
Fernando Solis
 
Subcadenas-en-C
Subcadenas-en-CSubcadenas-en-C
Subcadenas-en-C
Fernando Solis
 
BÚSQUEDA DE SUBCADENAS EN C
BÚSQUEDA DE SUBCADENAS EN CBÚSQUEDA DE SUBCADENAS EN C
BÚSQUEDA DE SUBCADENAS EN C
Fernando Solis
 
Almacenamiento de informacion en una estructura
Almacenamiento de informacion en una estructuraAlmacenamiento de informacion en una estructura
Almacenamiento de informacion en una estructura
Fernando Solis
 
Entrada y salida de datos
Entrada y salida de datosEntrada y salida de datos
Entrada y salida de datos
Fernando Solis
 
Longitud y Concatenacion
Longitud y ConcatenacionLongitud y Concatenacion
Longitud y Concatenacion
Fernando Solis
 
Lectura de datos de cadena
Lectura de datos de cadenaLectura de datos de cadena
Lectura de datos de cadena
Fernando Solis
 
Introducción a Tipos de Datos Abstractos (TDA)
Introducción a Tipos de Datos Abstractos (TDA)Introducción a Tipos de Datos Abstractos (TDA)
Introducción a Tipos de Datos Abstractos (TDA)
Fernando Solis
 
Archivos Binarios vs Archivos de Texto
Archivos Binarios vs Archivos de TextoArchivos Binarios vs Archivos de Texto
Archivos Binarios vs Archivos de Texto
Fernando Solis
 
DEFINICION DE CADENAS O STRINGS
DEFINICION DE CADENAS O STRINGSDEFINICION DE CADENAS O STRINGS
DEFINICION DE CADENAS O STRINGS
Fernando Solis
 
Declaración e inicialización de variables de tipo cadena
Declaración e inicialización de variables de tipo cadenaDeclaración e inicialización de variables de tipo cadena
Declaración e inicialización de variables de tipo cadena
Fernando Solis
 
Conversion de Strings
Conversion de StringsConversion de Strings
Conversion de Strings
Fernando Solis
 
Comparacion de arreglos Strings
Comparacion de arreglos StringsComparacion de arreglos Strings
Comparacion de arreglos Strings
Fernando Solis
 
Cadenas y/o strings
Cadenas y/o stringsCadenas y/o strings
Cadenas y/o strings
Fernando Solis
 
Asignacion
AsignacionAsignacion
Asignacion
Fernando Solis
 
Acceso en tipos de datos abstractos
Acceso en tipos de datos abstractosAcceso en tipos de datos abstractos
Acceso en tipos de datos abstractos
Fernando Solis
 
Arreglo Orden Seleccion
Arreglo  Orden SeleccionArreglo  Orden Seleccion
Arreglo Orden Seleccion
Fernando Solis
 
Algoritmos de Busqueda
Algoritmos de BusquedaAlgoritmos de Busqueda
Algoritmos de Busqueda
Fernando Solis
 
Quick Sort
Quick SortQuick Sort
Quick Sort
Fernando Solis
 

More from Fernando Solis (20)

Concepto y definición de tipos de Datos Abstractos en c++.pptx
Concepto y definición de tipos de Datos Abstractos en c++.pptxConcepto y definición de tipos de Datos Abstractos en c++.pptx
Concepto y definición de tipos de Datos Abstractos en c++.pptx
 
AULA INVERTIDA.pdf
AULA INVERTIDA.pdfAULA INVERTIDA.pdf
AULA INVERTIDA.pdf
 
Subcadenas-en-C
Subcadenas-en-CSubcadenas-en-C
Subcadenas-en-C
 
BÚSQUEDA DE SUBCADENAS EN C
BÚSQUEDA DE SUBCADENAS EN CBÚSQUEDA DE SUBCADENAS EN C
BÚSQUEDA DE SUBCADENAS EN C
 
Almacenamiento de informacion en una estructura
Almacenamiento de informacion en una estructuraAlmacenamiento de informacion en una estructura
Almacenamiento de informacion en una estructura
 
Entrada y salida de datos
Entrada y salida de datosEntrada y salida de datos
Entrada y salida de datos
 
Longitud y Concatenacion
Longitud y ConcatenacionLongitud y Concatenacion
Longitud y Concatenacion
 
Lectura de datos de cadena
Lectura de datos de cadenaLectura de datos de cadena
Lectura de datos de cadena
 
Introducción a Tipos de Datos Abstractos (TDA)
Introducción a Tipos de Datos Abstractos (TDA)Introducción a Tipos de Datos Abstractos (TDA)
Introducción a Tipos de Datos Abstractos (TDA)
 
Archivos Binarios vs Archivos de Texto
Archivos Binarios vs Archivos de TextoArchivos Binarios vs Archivos de Texto
Archivos Binarios vs Archivos de Texto
 
DEFINICION DE CADENAS O STRINGS
DEFINICION DE CADENAS O STRINGSDEFINICION DE CADENAS O STRINGS
DEFINICION DE CADENAS O STRINGS
 
Declaración e inicialización de variables de tipo cadena
Declaración e inicialización de variables de tipo cadenaDeclaración e inicialización de variables de tipo cadena
Declaración e inicialización de variables de tipo cadena
 
Conversion de Strings
Conversion de StringsConversion de Strings
Conversion de Strings
 
Comparacion de arreglos Strings
Comparacion de arreglos StringsComparacion de arreglos Strings
Comparacion de arreglos Strings
 
Cadenas y/o strings
Cadenas y/o stringsCadenas y/o strings
Cadenas y/o strings
 
Asignacion
AsignacionAsignacion
Asignacion
 
Acceso en tipos de datos abstractos
Acceso en tipos de datos abstractosAcceso en tipos de datos abstractos
Acceso en tipos de datos abstractos
 
Arreglo Orden Seleccion
Arreglo  Orden SeleccionArreglo  Orden Seleccion
Arreglo Orden Seleccion
 
Algoritmos de Busqueda
Algoritmos de BusquedaAlgoritmos de Busqueda
Algoritmos de Busqueda
 
Quick Sort
Quick SortQuick Sort
Quick Sort
 

Recently uploaded

Clase Prensencial, Actividad 2.pdf.......
Clase Prensencial, Actividad 2.pdf.......Clase Prensencial, Actividad 2.pdf.......
Clase Prensencial, Actividad 2.pdf.......
LuanaJaime1
 
200. Efemerides junio para trabajar en periodico mural
200. Efemerides junio para trabajar en periodico mural200. Efemerides junio para trabajar en periodico mural
200. Efemerides junio para trabajar en periodico mural
shirherrer
 
Este documento contiene, el programa completo de un acto para realizar la pro...
Este documento contiene, el programa completo de un acto para realizar la pro...Este documento contiene, el programa completo de un acto para realizar la pro...
Este documento contiene, el programa completo de un acto para realizar la pro...
romina395894
 
La necesidad de bienestar y el uso de la naturaleza.pdf
La necesidad de bienestar y el uso de la naturaleza.pdfLa necesidad de bienestar y el uso de la naturaleza.pdf
La necesidad de bienestar y el uso de la naturaleza.pdf
JonathanCovena1
 
La vida de Martin Miguel de Güemes para niños de primaria
La vida de Martin Miguel de Güemes para niños de primariaLa vida de Martin Miguel de Güemes para niños de primaria
La vida de Martin Miguel de Güemes para niños de primaria
EricaCouly1
 
CONCURSOS EDUCATIVOS 2024-PRESENTACIÓN ORIENTACIONES ETAPA IE (1).pptx
CONCURSOS EDUCATIVOS 2024-PRESENTACIÓN ORIENTACIONES ETAPA IE (1).pptxCONCURSOS EDUCATIVOS 2024-PRESENTACIÓN ORIENTACIONES ETAPA IE (1).pptx
CONCURSOS EDUCATIVOS 2024-PRESENTACIÓN ORIENTACIONES ETAPA IE (1).pptx
CARMENSnchez854591
 
Hablemos de ESI para estudiantes Cuadernillo
Hablemos de ESI para estudiantes CuadernilloHablemos de ESI para estudiantes Cuadernillo
Hablemos de ESI para estudiantes Cuadernillo
Mónica Sánchez
 
Prueba/test conoce tus heridas de la infancia
Prueba/test conoce tus heridas de la infanciaPrueba/test conoce tus heridas de la infancia
Prueba/test conoce tus heridas de la infancia
LudmilaOrtega3
 
CORREOS SEGUNDO 2024 HONORIO DELGADO ESPINOZA
CORREOS SEGUNDO 2024 HONORIO DELGADO ESPINOZACORREOS SEGUNDO 2024 HONORIO DELGADO ESPINOZA
CORREOS SEGUNDO 2024 HONORIO DELGADO ESPINOZA
Sandra Mariela Ballón Aguedo
 
Lecciones 11 Esc. Sabática. El conflicto inminente docx
Lecciones 11 Esc. Sabática. El conflicto inminente docxLecciones 11 Esc. Sabática. El conflicto inminente docx
Lecciones 11 Esc. Sabática. El conflicto inminente docx
Alejandrino Halire Ccahuana
 
Los Dominios y Reinos de los Seres Vivos
Los Dominios y Reinos de los Seres VivosLos Dominios y Reinos de los Seres Vivos
Los Dominios y Reinos de los Seres Vivos
karlafreire0608
 
Mi Comunidad En El Sector Monterrey-Poste Blanco
Mi Comunidad En El Sector Monterrey-Poste BlancoMi Comunidad En El Sector Monterrey-Poste Blanco
Mi Comunidad En El Sector Monterrey-Poste Blanco
Ruth Noemí Soto Villegas
 
POESÍA POR EL DIA DEL PADREEEEEEEEEE.pdf
POESÍA POR EL DIA DEL PADREEEEEEEEEE.pdfPOESÍA POR EL DIA DEL PADREEEEEEEEEE.pdf
POESÍA POR EL DIA DEL PADREEEEEEEEEE.pdf
karlavasquez49
 
1° T3 Examen Zany de primer grado compl
1° T3 Examen Zany  de primer grado compl1° T3 Examen Zany  de primer grado compl
1° T3 Examen Zany de primer grado compl
ROCIORUIZQUEZADA
 
Power Point: El conflicto inminente (Bosquejo)
Power Point: El conflicto inminente (Bosquejo)Power Point: El conflicto inminente (Bosquejo)
Power Point: El conflicto inminente (Bosquejo)
https://gramadal.wordpress.com/
 
Soluciones Examen de Selectividad. Geografía junio 2024 (Convocatoria Ordinar...
Soluciones Examen de Selectividad. Geografía junio 2024 (Convocatoria Ordinar...Soluciones Examen de Selectividad. Geografía junio 2024 (Convocatoria Ordinar...
Soluciones Examen de Selectividad. Geografía junio 2024 (Convocatoria Ordinar...
Juan Martín Martín
 
APUNTES UNIDAD I ECONOMIA EMPRESARIAL .pdf
APUNTES UNIDAD I ECONOMIA EMPRESARIAL .pdfAPUNTES UNIDAD I ECONOMIA EMPRESARIAL .pdf
APUNTES UNIDAD I ECONOMIA EMPRESARIAL .pdf
VeronicaCabrera50
 
ACERTIJO DESCIFRANDO CÓDIGO DEL CANDADO DE LA TORRE EIFFEL EN PARÍS. Por JAVI...
ACERTIJO DESCIFRANDO CÓDIGO DEL CANDADO DE LA TORRE EIFFEL EN PARÍS. Por JAVI...ACERTIJO DESCIFRANDO CÓDIGO DEL CANDADO DE LA TORRE EIFFEL EN PARÍS. Por JAVI...
ACERTIJO DESCIFRANDO CÓDIGO DEL CANDADO DE LA TORRE EIFFEL EN PARÍS. Por JAVI...
JAVIER SOLIS NOYOLA
 
Cronica-de-una-Muerte-Anunciada - Gabriel Garcia Marquez.pdf
Cronica-de-una-Muerte-Anunciada - Gabriel Garcia Marquez.pdfCronica-de-una-Muerte-Anunciada - Gabriel Garcia Marquez.pdf
Cronica-de-una-Muerte-Anunciada - Gabriel Garcia Marquez.pdf
RicardoValdiviaVega
 

Recently uploaded (20)

Clase Prensencial, Actividad 2.pdf.......
Clase Prensencial, Actividad 2.pdf.......Clase Prensencial, Actividad 2.pdf.......
Clase Prensencial, Actividad 2.pdf.......
 
200. Efemerides junio para trabajar en periodico mural
200. Efemerides junio para trabajar en periodico mural200. Efemerides junio para trabajar en periodico mural
200. Efemerides junio para trabajar en periodico mural
 
Este documento contiene, el programa completo de un acto para realizar la pro...
Este documento contiene, el programa completo de un acto para realizar la pro...Este documento contiene, el programa completo de un acto para realizar la pro...
Este documento contiene, el programa completo de un acto para realizar la pro...
 
La necesidad de bienestar y el uso de la naturaleza.pdf
La necesidad de bienestar y el uso de la naturaleza.pdfLa necesidad de bienestar y el uso de la naturaleza.pdf
La necesidad de bienestar y el uso de la naturaleza.pdf
 
La vida de Martin Miguel de Güemes para niños de primaria
La vida de Martin Miguel de Güemes para niños de primariaLa vida de Martin Miguel de Güemes para niños de primaria
La vida de Martin Miguel de Güemes para niños de primaria
 
CONCURSOS EDUCATIVOS 2024-PRESENTACIÓN ORIENTACIONES ETAPA IE (1).pptx
CONCURSOS EDUCATIVOS 2024-PRESENTACIÓN ORIENTACIONES ETAPA IE (1).pptxCONCURSOS EDUCATIVOS 2024-PRESENTACIÓN ORIENTACIONES ETAPA IE (1).pptx
CONCURSOS EDUCATIVOS 2024-PRESENTACIÓN ORIENTACIONES ETAPA IE (1).pptx
 
Hablemos de ESI para estudiantes Cuadernillo
Hablemos de ESI para estudiantes CuadernilloHablemos de ESI para estudiantes Cuadernillo
Hablemos de ESI para estudiantes Cuadernillo
 
Prueba/test conoce tus heridas de la infancia
Prueba/test conoce tus heridas de la infanciaPrueba/test conoce tus heridas de la infancia
Prueba/test conoce tus heridas de la infancia
 
CORREOS SEGUNDO 2024 HONORIO DELGADO ESPINOZA
CORREOS SEGUNDO 2024 HONORIO DELGADO ESPINOZACORREOS SEGUNDO 2024 HONORIO DELGADO ESPINOZA
CORREOS SEGUNDO 2024 HONORIO DELGADO ESPINOZA
 
Lecciones 11 Esc. Sabática. El conflicto inminente docx
Lecciones 11 Esc. Sabática. El conflicto inminente docxLecciones 11 Esc. Sabática. El conflicto inminente docx
Lecciones 11 Esc. Sabática. El conflicto inminente docx
 
Los Dominios y Reinos de los Seres Vivos
Los Dominios y Reinos de los Seres VivosLos Dominios y Reinos de los Seres Vivos
Los Dominios y Reinos de los Seres Vivos
 
Mi Comunidad En El Sector Monterrey-Poste Blanco
Mi Comunidad En El Sector Monterrey-Poste BlancoMi Comunidad En El Sector Monterrey-Poste Blanco
Mi Comunidad En El Sector Monterrey-Poste Blanco
 
POESÍA POR EL DIA DEL PADREEEEEEEEEE.pdf
POESÍA POR EL DIA DEL PADREEEEEEEEEE.pdfPOESÍA POR EL DIA DEL PADREEEEEEEEEE.pdf
POESÍA POR EL DIA DEL PADREEEEEEEEEE.pdf
 
1° T3 Examen Zany de primer grado compl
1° T3 Examen Zany  de primer grado compl1° T3 Examen Zany  de primer grado compl
1° T3 Examen Zany de primer grado compl
 
Power Point: El conflicto inminente (Bosquejo)
Power Point: El conflicto inminente (Bosquejo)Power Point: El conflicto inminente (Bosquejo)
Power Point: El conflicto inminente (Bosquejo)
 
Soluciones Examen de Selectividad. Geografía junio 2024 (Convocatoria Ordinar...
Soluciones Examen de Selectividad. Geografía junio 2024 (Convocatoria Ordinar...Soluciones Examen de Selectividad. Geografía junio 2024 (Convocatoria Ordinar...
Soluciones Examen de Selectividad. Geografía junio 2024 (Convocatoria Ordinar...
 
APUNTES UNIDAD I ECONOMIA EMPRESARIAL .pdf
APUNTES UNIDAD I ECONOMIA EMPRESARIAL .pdfAPUNTES UNIDAD I ECONOMIA EMPRESARIAL .pdf
APUNTES UNIDAD I ECONOMIA EMPRESARIAL .pdf
 
ACERTIJO DESCIFRANDO CÓDIGO DEL CANDADO DE LA TORRE EIFFEL EN PARÍS. Por JAVI...
ACERTIJO DESCIFRANDO CÓDIGO DEL CANDADO DE LA TORRE EIFFEL EN PARÍS. Por JAVI...ACERTIJO DESCIFRANDO CÓDIGO DEL CANDADO DE LA TORRE EIFFEL EN PARÍS. Por JAVI...
ACERTIJO DESCIFRANDO CÓDIGO DEL CANDADO DE LA TORRE EIFFEL EN PARÍS. Por JAVI...
 
A VISITA DO SENHOR BISPO .
A VISITA DO SENHOR BISPO                .A VISITA DO SENHOR BISPO                .
A VISITA DO SENHOR BISPO .
 
Cronica-de-una-Muerte-Anunciada - Gabriel Garcia Marquez.pdf
Cronica-de-una-Muerte-Anunciada - Gabriel Garcia Marquez.pdfCronica-de-una-Muerte-Anunciada - Gabriel Garcia Marquez.pdf
Cronica-de-una-Muerte-Anunciada - Gabriel Garcia Marquez.pdf
 

Grafos

  • 2. TEORÍA DE GRAFOS • LOS GRAFOS SON ESTRUCTURAS DISCRETAS QUE APARECEN UBICUAMENTE EN CADA DISCIPLINA DONDE SE REQUIERE MODELAR ALGO. • EN GENERAL LOS GRAFOS SON MAPAS CONCEPTUALES QUE AYUDAN A REPRESENTAR EL CONOCIMIENTO. • LOS GRAFOS TIENE MUCHAS APLICACIONES EN PROBLEMAS DE INGENIERÍA, COMPUTACIÓN, BIOLOGÍA, FÍSICA, URBANISMO, COMUNICACIONES, ECONOMÍA, REDES SOCIALES, ENTRE MUCHAS OTRAS. 2
  • 3. TEORÍA DE GRAFOS (CONT.) • APLICACIONES DE LOS GRAFOS: • INTERNET Y LOS PROTOCOLOS DE COMUNICACIONES (TCP/IP, SMTP, FTP, ROUTERS, ETC.) • DISEÑO DE REDES DE COMUNICACIONES Y TRANSPORTE (REDES COMPUTACIONALES, CARRETERAS, AGUAS, ELECTRICIDAD, TELECOMUNICACIONES, AVIACIÓN, SATÉLITES, AERO-ESPACIAL, FLOTAS DE VEHÍCULOS, ETC.) • ESTRUCTURA DE DATOS • ALGORITMOS COMPUTACIONALES • NAVEGADOR GPS (GOOGLE MAPS) 3
  • 4. TEORÍA DE GRAFOS (CONT.) • APLICACIONES DE LOS GRAFOS: • ECONOMÍA (BOLSA, TRANSACCIONES ECONÓMICAS, MODELOS DE MERCADO, ETC.) • EMPRESA (LOCALIZACIÓN, ESTRATEGIA, TEORÍA DE JUEGOS, ANÁLISIS DE LA COMPETENCIA, LOGÍSTICA, CRM, ERP, MRP, SCHEDULING, ESQUEMA ORGANIZACIONAL, ETC.) • REDES SOCIALES (FACEBOOK, SKYPE, MSN) • POLÍTICA Y MARKETING • SEGURIDAD Y PREVENCIÓN DEL TERRORISMO • INTELIGENCIA MILITAR 4
  • 5. TEORÍA DE GRAFOS (CONT.) • APLICACIONES DE LOS GRAFOS: • OCIO (VIDEO JUEGOS, SIMULACIÓN E IA) • DOMÓTICA, ROBÓTICA, AUTOMATIZACIÓN, CONTROL Y GESTIÓN DE REDES, ETC. • LA WEB (ES UN GRAFO CUYA ESTRUCTURA CAMBIA CADA SEGUNDO) • WEB SEMÁNTICA • INVESTIGACIÓN MÉDICA, BIOGENÉTICA (SECUENCIACIÓN ADN) • BIOLOGÍA, MEDIO-AMBIENTE, CAMBIO CLIMÁTICO • ÁRBOLES GENEALÓGICOS 5
  • 6. PROPIEDADES DE LOS GRAFOS • ADYACENCIA. DOS ARISTAS SON ADYACENTES SI TIENEN UN VÉRTICE EN COMÚN, Y DOS VÉRTICES SON ADYACENTES SI UNA ARISTA LOS UNE. • INCIDENCIA. UNA ARISTA ES INCIDENTE A UN VÉRTICE SI ÉSTA LO UNE A OTRO. • PONDERACIÓN. CORRESPONDE A UNA FUNCIÓN QUE ASOCIA A CADA ARISTA UN VALOR (COSTO, PESO, LONGITUD, ETC.), PARA AUMENTAR LA EXPRESIVIDAD DEL MODELO. • ETIQUETADO. DISTINCIÓN QUE SE HACE A LOS VÉRTICES Y/O ARISTAS MEDIANTE UNA MARCA QUE LOS HACE UNÍVOCAMENTE DISTINGUIBLES DEL RESTO. 6
  • 7. ¿QUÉ ES UN GRAFO? • UN GRAFO G CONSISTE EN UN CONJUNTO NO VACÍO DE VÉRTICES O NODOS V Y UN CONJUNTO DE ARCOS O ARISTAS E  G = (V,E). • GRAFO DEL GRIEGO GRAFOS: DIBUJO, IMAGEN. • CADA E Є E TIENE UN PAR (V1,V2) Є V X V ASOCIADO; ES DECIR, E CONECTA V1 CON V2. • EL ORDEN DEL GRAFO G A SU NÚMERO DE VÉRTICES  G = |V|. • EL GRADO DE UN VÉRTICE O NODO V Є V ES IGUAL AL NÚMERO DE ARCOS O ARISTAS QUE LO TIENEN COMO EXTREMO. 7
  • 8. ¿QUÉ ES UN GRAFO? (CONT.) • VÉRTICES (NODOS). ELEMENTOS (OBJETOS) QUE FORMAN UN GRAFO. CADA UNO LLEVA ASOCIADA UN GRADO CARACTERÍSTICO SEGÚN LA SITUACIÓN, QUE SE CORRESPONDE CON LA CANTIDAD DE ARCOS O ARISTAS QUE CONFLUYEN EN DICHO VÉRTICE. • ARCOS O ARISTAS. RELACIONES ENTRE LOS ELEMENTOS QUE FORMAN EL GRAFO. EXISTEN LOS SIGUIENTES TIPOS: • RAMAS. ARCO O ARISTA QUE UNEN UN VÉRTICE CON OTRO. • PARALELAS (MÚLTIPLES). ARCOS O ARISTAS CONJUNTAS SI EL VÉRTICE INICIAL Y FINAL SON EL MISMO. 8
  • 9. ¿QUÉ ES UN GRAFO? (CONT.) • UN GRAFO PONDERADO G = (V,E,W) ES UN GRAFO EN EL QUE A CADA ARCO O ARISTA 𝑒 ∈ 𝐸 SE LE ASOCIA UN PESO 𝑤 𝑒 ∈ ℝ. • EN UN GRAFO DIRIGIDO, UN VÉRTICES ES ADYACENTE A OTRO SI ESTÁN CONECTADOS POR UN ARCO (COLA → CABEZA), DONDE EL VÉRTICE CABEZA ES ADYACENTE AL VÉRTICE COLA. • EN TAL CASO, EL VÉRTICES COLA ES INCIDENTE AL VÉRTICE CABEZA. • EN UN GRAFO NO DIRIGIDO, DOS VÉRTICES SON ADYACENTES SI ESTÁN CONECTADOS POR UNA ARISTA. • EN TAL CASO, CADA UNO DE ESTOS VÉRTICES ES INCIDENTE A DICHA ARISTA. 9
  • 10. GRAFO BIPARTITO • UN GRAFO BIPARTITO (O BIPARTIDO) ES UN GRAFO SIMPLE G = (N,E) CUYOS VÉRTICES SE PUEDEN SEPARAR EN DOS CONJUNTOS DISJUNTOS U Y V, DE MANERA QUE LAS ARISTAS SÓLO PUEDEN CONECTAR VÉRTICES DE UN CONJUNTO CON VÉRTICES DEL OTRO. • LOS GRAFOS BIPARTITOS SUELEN REPRESENTARSE GRÁFICAMENTE CON DOS COLUMNAS (O FILAS) DE VÉRTICES Y LAS ARISTAS UNIENDO VÉRTICES DE COLUMNAS (O FILAS) DIFERENTES. 10
  • 11. GRAFO BIPARTITO • LOS DOS CONJUNTOS U Y V PUEDEN SER PENSADOS COMO UN COLOREO DEL GRAFO CON DOS COLORES. • UN GRAFO SIMPLE ES BIPARTITO SI Y SOLO SI ES POSIBLE ASIGNAR UNO DE DOS COLORES DIFERENTES A CADA VÉRTICE DEL GRAFO, DE TAL FORMA QUE NINGÚN PAR (U,V) DE VÉRTICES ADYACENTES RECIBE EL MISMO COLOR. • UN GRAFO BIPARTITO CON LA PARTICIÓN DE LOS VÉRTICES EN U Y V SUELE DENOTARSE G = (U, V, E). • SI |U| =|V|, ESTO ES, SI LOS DOS SUBCONJUNTOS TIENE LA MISMA CANTIDAD DE ELEMENTOS O CARDINALIDAD, DECIMOS QUE EL GRAFO BIPARTITO G ES BALANCEADO. 11
  • 14. ALGORITMOS DE GRAFOS DIRIGIDOS • ALGORITMOS DE DETERMINACIÓN DE LOS CAMINOS MÁS CORTOS: • ALGORITMO DE DIJKSTRA. • ALGORITMO DE FLOYD-WARSHALL. • ALGORITMOS DE RECORRIDO O BÚSQUEDA: • ALGORITMO DE BÚSQUEDA EN ANCHURA O AMPLITUD. • ALGORITMO DE BÚSQUEDA EN PROFUNDIDAD. • BOSQUES ABARCADORES. 14
  • 15. ALGORITMOS DE GRAFOS DIRIGIDOS – ALGORITMO DE DIJKSTRA • EL ALGORITMO DE DIJKSTRA, TAMBIÉN LLAMADO ALGORITMO DE CAMINOS MÍNIMOS, ES UN ALGORITMO PARA LA DETERMINACIÓN DEL CAMINO MÁS CORTO DADO UN VÉRTICE ORIGEN AL RESTO DE VÉRTICES EN UN GRAFO DIRIGIDO Y CON PESOS EN CADA ARCO. • SU NOMBRE SE REFIERE A EDSGER DIJKSTRA, QUIEN LO DESCRIBIÓ POR PRIMERA VEZ EN 1959. 15
  • 16. ALGORITMOS DE GRAFOS DIRIGIDOS – ALGORITMO DE DIJKSTRA (CONT.) • LA IDEA SUBYACENTE EN ESTE ALGORITMO CONSISTE EN IR EXPLORANDO TODOS LOS CAMINOS MÁS CORTOS QUE PARTEN DEL VÉRTICE ORIGEN Y QUE LLEVAN A TODOS LOS DEMÁS VÉRTICES. • CUANDO SE OBTIENE EL CAMINO MÁS CORTO DESDE EL VÉRTICE ORIGEN, AL RESTO DE VÉRTICES QUE COMPONEN EL GRAFO, EL ALGORITMO SE DETIENE. • EL ALGORITMO ES UNA ESPECIALIZACIÓN DE LA BÚSQUEDA DE COSTO UNIFORME, Y COMO TAL, NO FUNCIONA EN GRAFOS CON ARISTAS DE COSTO NEGATIVO. 16
  • 17. ALGORITMOS DE GRAFOS DIRIGIDOS – ALGORITMO DE DIJKSTRA (CONT.) • DESCRIPCIÓN DETALLADA: • SEA G=(V,E) UN GRAFO DIRIGIDO Y ETIQUETADO. • SEAN LOS VÉRTICES A  V Y Z  V; A ES EL VÉRTICE DE ORIGEN Y Z EL VÉRTICE DE DESTINO. • SEA UN CONJUNTO C  V, QUE CONTIENE LOS VÉRTICES DE V CUYO CAMINO MÁS CORTO DESDE A TODAVÍA NO SE CONOCE. • SEA UN VECTOR D, CON TANTAS DIMENSIONES COMO ELEMENTOS TIENE V, Y QUE “GUARDA” LAS DISTANCIAS ENTRE A Y CADA UNO DE LOS VÉRTICES DE V. • SEA, FINALMENTE, OTRO VECTOR, P, CON LAS MISMAS DIMENSIONES QUE D, Y QUE CONSERVA LA INFORMACIÓN SOBRE QUÉ VÉRTICE PRECEDE A CADA UNO DE LOS VÉRTICES EN EL CAMINO. 17
  • 18. ALGORITMOS DE GRAFOS DIRIGIDOS – ALGORITMO DE DIJKSTRA (CONT.) • DESCRIPCIÓN DETALLADA: • EL ALGORITMO PARA DETERMINAR EL CAMINO DE LONGITUD MÍNIMA ENTRE LOS VÉRTICES A Y Z ES: C  V. 1. PARA TODO VÉRTICE I  C, I ≠ A, SE ESTABLECE DI  ∞ ; DA  0. 2. PARA TODO VÉRTICE I  C SE ESTABLECE PI = A. 3. SE OBTIENE EL VÉRTICE S  C TAL QUE NO EXISTE OTRO VÉRTICE W ∈ C TAL QUE DW < DS. • SI S = Z ENTONCES SE HA TERMINADO EL ALGORITMO. 4. SE ELIMINA DE C EL VÉRTICE S: C  C−{S}. 5. PARA CADA ARISTA E ∈ E DE LONGITUD L, QUE UNE EL VÉRTICE S CON ALGÚN OTRO VÉRTICE T ∈ C, • SI L + DS < DT, ENTONCES: • SE ESTABLECE DT  L + DS. • SE ESTABLECE PT  S. 6. SE REGRESA AL PASO 4. 18
  • 19. ALGORITMOS DE GRAFOS DIRIGIDOS – ALGORITMO DE DIJKSTRA (CONT.) • AL TERMINAR ESTE ALGORITMO, EN DZ ESTARÁ GUARDADA LA DISTANCIA MÍNIMA ENTRE A Y Z. • POR OTRO LADO, MEDIANTE EL VECTOR P SE PUEDE OBTENER EL CAMINO MÍNIMO: EN PZ ESTARÁ Y, EL VÉRTICE QUE PRECEDE A Z EN EL CAMINO MÍNIMO; EN PY ESTARÁ EL QUE PRECEDE A Y, Y ASÍ SUCESIVAMENTE, HASTA LLEGAR A ESTADO DE ENLACE. • APLICACIÓN WEB DEL ALGORITMO: • HTTP://NEO.LCC.UMA.ES/EVIRTUAL/CDD/APPLETS/DIS TANCIA%20CORTA/EXAMPLE2.HTML. 19
  • 20. ALGORITMOS DE GRAFOS DIRIGIDOS – ALGORITMO DE DIJKSTRA (CONT.) • EJEMPLO: • ENCONTRAR LOS CAMINOS MÁS CORTOS ENTRE EL VÉRTICE 1 Y TODOS LOS DEMÁS DEL SIGUIENTE GRAFO DIRIGIDO. 20