CADASTRE-SE
Temos Uma versão desta Revista Especificamente para SmartPhone
Mais Enxuta: Somente Vídeo Aulas e EVENTOS!
Music Player
l
PESQUISA OPERACIONAL
Disciplina: Teoria dos Grafos
Veja a seguir os seguintes conteúdos já disponíveis. Para tomar conhecimento da lista completa dos conteúdos vistos nesta disciplina, clique no ícone "PROGRAMA" acima. OBSERVAÇÃO: Alguns dos assuntos estão divididos em partes as quais podem ser acessadas clicando nos links abaixo.
1) Alguns teoremas sobre Grafos: Teoremas - 001 / Algumas Estratégias de Demonstração de Teoremas
(Ver mais em Lógica Matemática ou Álgebra das Proposições) /
2) Exercícios sobre Algoritmos Aleatorizados /
3) Ordem de Complexidade de um Algoritmo /
Alguns Sites ou Home-Page: Prof. Antônio Carlos Mariani - Departamento de Informática e Estatística-UFSC /
CURSO COMPLETO - BUSCA EM GRAFOS
Apostila de um Curso de Mestrado!
CAPÍTULO 1 - Definições Preliminares
CAPÍTULO 2 - Algoritmos de Busca em Grafos:
a) Definição; Completicidade; e Admissibilidade
b) Algoritmo de Busca HORIZONTAL
c) Algoritmo de Busca VERTICAL
CAPÍTULO 3 - Algoritmo de DIJKTRA
CAPÍTULO 4 - Algoritmo de DIJKSTRA com Custo Negativo
CAPÍTULO 5 - Introdução da Informação Heurística
CAPÍTULO 6 - Um Exemplo Prático de Aplicação do Algoritmo de DIJKSTRA
Teoria dos Grafos
Origem: Wikipédia, a enciclopédia livre.
A teoria dos grafos é um ramo da matemática que estuda as relações entre os objetos de um determinado conjunto. Para tal são empregadas estruturas chamadas de grafos, G(V,A), onde V é um conjunto não vazio de objetos denominados vértices e A é um conjunto de pares não ordenados de V, chamado arestas.
Dependendo da aplicação, arestas podem ou não ter direção, pode ser permitido ou não arestas ligarem um vértice a ele próprio e vértices e/ou arestas podem ter um peso (numérico) associado. Se as arestas têm uma direção associada (indicada por uma seta na representação gráfica) temos um grafo direcionado, grafo orientado ou digrafo. Um grafo com um único vértice e sem arestas é conhecido como o grafo trivial.
Estruturas que podem ser representadas por grafos estão em toda parte e muitos problemas de interesse prático podem ser formulados como questões sobre certos grafos. Por exemplo, a estrutura de links da Wikipédia pode ser representada por um dígrafo: os vértices são os artigos da Wikipédia e existe uma aresta do artigo A para o artigo B se, e somente se, A contém um link para B. Dígrafos são também usados para representar máquinas de estado finito. O desenvolvimento de algoritmos para manipular grafos é um importante tema da ciência da computação.
Grafo com 4 vértices e 6 arestas. É um grafo completo, conexo e planar.
Histórico
O artigo de Leonhard Euler, publicado em 1736, sobre o Problema das Sete Pontes de Königsberg, é considerado o primeiro resultado da teoria dos grafos. É também considerado um dos primeiros resultados topológicos na geometria; isto é, não dependente de quaisquer medidas (ver Teoria das Medidas). Isso ilustra a profunda conexão entre a teoria dos grafos e Topologia (ver também: Topologia-Espaços Métricos).
Definições de Grafos e Dígrafos
Na literatura, as definições básicas da teoria dos grafos variam bastante. Aqui estão as convenções usadas nesta enciclopédia.
Um grafo direcionado (também chamado digrafo ou Quiver) consiste de
· um conjunto V de vértices,
· um conjunto E de arestas e
· mapas s, t : E → V, onde s(e) é a fonte e t(e) é o alvo da aresta direcionada e.
Um grafo não direcionado (ou simplesmente grafo) é dado por
· um conjunto V de vértices,
· um conjunto E de arestas e
· uma função w : E → P(V) que associa a cada aresta um subconjunto de dois ou de um elemento de V, interpretado como os pontos terminais da aresta.
Em um grafo ou digrafo com pesos, uma função adicional E → R associa um valor a cada aresta, o que pode ser considerado seu "custo"; tais grafos surgem em Problemas de Rota Ótima tais como o Problema do Caixeiro Viajante.
Glossário dos conceitos básicos de teoria dos grafos
Representação Gráfica (Layout do Grafo)
Os grafos são geralmente representados graficamente da seguinte maneira: é desenhado um círculo para cada vértice, e para cada aresta é desenhado um arco conectando suas extremidades. Se o grafo for direcionado, seu sentido é indicado na aresta por uma seta.
Note que essa representação gráfica (o layout) não deve ser confundida com o grafo em si (a estrutura abstrata, não-gráfica). Vários diferentes layouts podem corresponder ao mesmo grafo. O que importa é quais vértices estão conectados entre si por quantas arestas.
O grafo de exemplo exibido à direita é um grafo simples com o conjunto de vértices V ={1, 2, 3, 4, 5, 6} e um conjunto de arestas E ={ {1,2}, {1,5}, {2,3}, {2,5}, {3,4}, {4,5}, {4,6} } (com o mapeamento w sendo a identidade).
Uma aresta conecta dois vértices; esses dois vértices são ditos como incidentes à aresta. A valência (ou grau) de um vértice é o número de arestas incidentes a ele, com loops contados duas vezes. No grafo de exemplo os vértices 1 e 3 possuem uma valência de 2, os vértices 2, 4 e 5 têm a valência de 3 e o vértice 6 tem a valência de 1. Se E é finito, então a valência total dos vértices é o dobro do número de arestas. Em um dígrafo, distingue-se o grau de saída (o número de arestas saindo de um vértice) e o grau de entrada (o número de arestas entrando em um vértice). O grau de um vértice é igual à soma dos graus de saída e de entrada.
Dois vértices são considerados adjacentes se uma aresta existe entre eles. No grafo acima, os vértices 1 e 2 são adjacentes, mas os vértices 2 e 4 não são. O conjunto de vizinhos de um vértice consiste de todos os vértices adjacentes a ele. No grafo-exemplo, o vértice 1 possui 2 vizinhos: vértice 2 e vértice 5. Para um grafo simples, o número de vizinhos de um vértice é igual à sua valência.
Na computação, um grafo finito direcionado ou não-direcionado (com, digamos, n vértices) é geralmente representado por sua matriz de adjacência: uma matriz n-por-n cujo valor na linha i e coluna j fornece o número de arestas do i-ésimo ao j-ésimo vértices.
Se for possível estabelecer um caminho de qualquer vértice para qualquer outro vértice de um grafo, diz-se que o grafo é conexo. Se for sempre possível estabelecer um caminho de qualquer vértice para qualquer outro vértice mesmo depois de remover k-1 vértices, então diz-se que o grafo está k-conexo. Note que um grafo está k-conexo se, e somente se, contém k caminhos independentes entre qualquer par de vértices. O grafo de exemplo acima é conexo (e portanto 1-conexo), mas não é 2-conexo.
Em um grafo genérico G, o corte associado a um conjunto X de vértices é o conjunto de todas as arestas que têm uma ponta em X e outra em V(G) - X, onde V(G) é o conjunto de todos os vértices pertencentes ao grafo G.
Um grafo com 6 vértices e 7 arestas
Tipos de grafos
· Grafo simples é um grafo não direcionado, sem laços e que existe no máximo uma aresta entre quaisquer dois vértices (sem arestas paralelas). No grafo de exemplo, (1, 2, 5, 1, 2, 3) é um caminho com comprimento 5, e (5, 2, 1) é um caminho simples de comprimento 2.
· Grafo completo é o grafo simples em que, para cada vértice do grafo, existe uma aresta conectando este vértice a cada um dos demais. Ou seja, todos os vértices do grafo possuem mesmo grau. O grafo completo de n vértices é frequentemente denotado porKn. Ele tem n(n-1)/2 arestas (correspondendo a todas as possíveis escolhas de pares de vértices).
· Grafo nulo é o grafo cujo conjunto de vértices é vazio.
· Grafo vazio é o grafo cujo conjunto de arestas é vazio.
· Grafo trivial é o grafo que possui apenas um vertice e nenhuma aresta.
· Grafo regular é um grafo em que todos os vértices tem o mesmo grau.
· Multigrafo é um grafo que permite múltiplas arestas ligando os mesmos vértices (arestas paralelas).
· Laço (loop) num grafo ou num digrafo é uma aresta e em E cujas terminações estão no mesmo vértice.
· Pseudografo é um grafo que contém arestas paralelas e laços.
· Ciclo (ou circuito) é um caminho que começa e acaba com o mesmo vértice. Ciclos de comprimento 1 são laços. No grafo de exemplo, (1, 2, 3, 4, 5, 2, 1) é um ciclo de comprimento 6. Um ciclo simples é um ciclo que tem um comprimento pelo menos de 3 e no qual o vértice inicial só aparece mais uma vez, como vértice final, e os outros vértices aparecem só uma vez. No grafo acima, (1, 5, 2, 1) é um ciclo simples. Um grafo chama-se acíclico se não contém ciclos simples.
· Ponto de articulação ou Vértice de corte é um vértice cuja remoção desliga um grafo. Uma ponte é uma aresta cuja remoção desliga um grafo. Um componente biconectado é um conjunto máximo de arestas tal que qualquer par de arestas do conjunto fazem parte de um ciclo simples comum. O contorno de um grafo é o comprimento do ciclo simples mais curto no grafo. O contorno de um grafo acíclico é, por definição, infinito.
· Árvore é um grafo simples acíclico e conexo. Às vezes, um vértice da árvore é distinto e chamado de raiz. Árvores são comumente usadas como estruturas de dados em informática (veja estrutura de dados em árvore).
· Floresta é um conjunto de árvores; equivalentemente a uma floresta, em algum grafo acíclico.
· Subgrafo de um grafo G é um grafo cujo conjunto dos vértices é um subconjunto do conjunto de vértices G, cujo conjunto de arestas é um subconjunto do conjunto de arestas de G, e cuja função w é uma restrição da função de G
· Subgrafo gerador é aquele obtido pela remoção de uma ou mais arestas de um outro grafo, dizemos então que este novo grafo obtido é gerador do primeiro,
· Subgrafo induzido é obtido pela remoção de vértices e consequente das arestas relacionadas com ele de um outro grafo, dizemos que este novo grafo é um grafo induzido do original.
· Grafo Parcial de um grafo G é um subgrafo com o mesmo conjunto de vértices que G. Uma árvore parcial é um grafo parcial que é árvore. Todo grafo tem pelo menos uma árvore parcial.
· Clique em um grafo é um subgrafo que também é um grafo completo. No grafo do exemplo acima, os vértices 1, 2 e 5 formam um clique.
· Conjunto independente em um grafo é um conjunto de vértices não adjacentes entre si. No exemplo acima, os vértices 1, 3 e 6 formam um conjunto independente e 3, 5 e 6 são outro conjunto independente.
· Grafo planar é aquele que pode ser representado em um plano sem qualquer intersecção entre arestas. O grafo do exemplo é planar; o grafo completo de n vertices, para n> 4, não é planar.
· Caminho é uma sequência de vértices tal que de cada um dos vértices existe uma aresta para o vértice seguinte. Um caminho é chamado simples se nenhum dos vértices no caminho se repete. O comprimento do caminho é o número de arestas que o caminho usa, contando-se arestas múltiplas vezes. O custo de um caminho num grafo balanceado é a soma dos custos das arestas atravessadas. Dois caminhos são independentes se não tiverem nenhum vértice em comum, excepto o primeiro e o último.
· Caminho euleriano em um grafo é o caminho que usa cada aresta exatamente uma vez. Se tal caminho existir, o grafo é chamado traversável. Um ciclo euleriano é um ciclo que usa cada aresta exatamente uma vez.
· Caminho hamiltoniano em um grafo é o caminho que visita cada vertice exatamente uma vez. Um ciclo hamiltoniano é um ciclo que visita cada vértice uma só vez. O grafo do exemplo contém um caminho hamiltoniano. Enquanto determinar se um dado grafo contém um caminho ou ciclo euleriano é trivial, o mesmo problema para caminhos e ciclos hamiltonianos é extremamente árduo.
· Lema do aperto de mãos diz que se os convidados de uma festa apertarem as mãos quando se encontrarem pela primeira vez, o número de convidados que apertam a mão um número ímpar de vezes é par. Também em grafos não direcionados a soma dos graus de todos os vértices é igual ao dobro do número de arestas.
· Grafo bipartido é o grafo cujos vértices podem ser divididos em dois conjuntos, nos quais não há arestas entre vértices de um mesmo conjunto. Para um grafo ser bipartido ele não pode conter circuitos de comprimento ímpar.
1. Se um grafo G é bipartido, todo o circuito de G possui comprimento par.Sejam V1 e V2 os dois conjuntos em que, de acordo com a definição de grafo bipartido, se particiona V(G). Toda a aresta de G conecta um vértice em V1 com outro em V2. Assim sendo, se X for um vértice de V1, para “voltar” a esse vértice terá de se ir a V2 e voltar a V1 um número indeterminado de vezes, e de cada vez serão percorridas duas arestas, uma de um vértice em V1 para um vértice em V2 e outra de um vértice em V2 para um vértice em V1. Logo, o número de arestas a percorrer será par, ou seja, o comprimento do circuito é par.
2. Se todo o circuito de um grafo G possui comprimento par, então o grafo é bipartido.Seja G um grafo em que todo o circuito tem comprimento par, e seja X um vértice de G. Denotemos por V1 o conjunto formado por X e por todos os vértices cuja distância a X é par. Seja V2=V(G)\V1 (isto é, o conjunto formado pelos vértices de G que não pertencem a V1). Pretende mostrar-se que não existe qualquer aresta que conecte vértices de V1 ou vértices de V2. Suponhamos a existência de tal aresta, isto é, suponhamos a existência de dois vértices em V1 (ou V2), digamos Xi e Xj, conectados por uma aresta. Ora existe já um caminho de comprimento par entre Xi e Xj, já que existem caminhos, ambos de comprimento par (ou ímpar, no caso de Xi e Xj pertencerem a V2), entre Xi e X e entre X e Xj. Se a esse caminho juntarmos a aresta {Xi;Xj} obtemos um circuito de comprimento ímpar o que contraria a hipótese de apenas existirem circuitos de comprimento par.
· Grafo bipartido completo é o grafo bipartido, cujo qualquer vértice do primeiro conjunto é adjacente a todos vértices do segundo conjunto
· Grafo k-partido ou grafo de k-coloração é um grafo cujos vértices podem ser particionados em k conjuntos disjuntos, nos quais não há arestas entre vértices de um mesmo conjunto. Um grafo 2-partido é o mesmo que grafo bipartido.
· Emparelhamento de grafos consiste em partir o grafo em conjuntos de vértices a qual não compartilham nenhuma aresta entre eles.
· Teorema das quatro cores é baseado no problema das cores necessárias para se colorir um mapa sem que os países vizinhos compartilhem da mesma cor. Transformando o mapa em um grafo pode-se provar que pode-se representar qualquer mapa (um grafo planar) com apenas 4 cores (4 partições).
· Percurso árvores:
· Percorrimento sistemático em todos os vértices e arestas do grafo. Grafo pode ser dirigido ou não.
· O percurso em árvores é o processo de visitar cada nó da árvore exatamente uma vez.
· O percurso pode ser interpretado como colocar todos os nós em uma linha, não existe uma ordem para ser seguida.
· Existem n percursos diferentes, quase todos caóticos.
· Os básicos são percurso em profundidade e percurso em largura
· Fila: busca em largura
· Pilha: busca em profundidade
· Busca em extensão ou largura: (Breadth-First Search ou BFS). A propriedade especial está no fato de a árvore não possuir ciclos: dados dois vértices quaisquer, existe exatamente 1 caminho entre eles. Um percurso em extensão é visitar cada nó começando do menor nível move-se para os níveis mais altos nível após nível, visitando cada nó da esquerda para a direita. Sua implementação é direta quando uma fila é utilizada. Depois que um nó é visitado, seus filhos, se houver algum, são colocados no final da fila e o nó no início da fila é visitado. Assim, os nós do nível n+1 serão visitados somente depois de ter visitados todos os nós do nível n. Computa a menor distância para todos os vértices alcançaveis. O sub-grafo contendo os caminhos percorridos é chamado de breadth-first tree.
· Busca em profundidade (Depth-first search ou DFS): Um algoritmo de busca em profundidade realiza uma busca não-informada que progride através da expansão do primeiro nó filho da árvore de busca, e se aprofunda cada vez mais, até que o alvo da busca seja encontrado ou até que ele se depare com um nó que não possui filhos (nó folha). Então a busca retrocede (backtrack) e começa no próximo nó. Numa implementação não-recursiva, todos os nós expandidos recentemente são adicionados a uma pilha, para realizar a exploração. A complexidade espacial de um algoritmo de busca em profundidade é muito menor que a de um algoritmo de busca em largura. A complexidade temporal de ambos algoritmos são proporcionais ao número de vértices somados ao número de arestas dos grafos aos quais eles atravessam. Quando ocorrem buscas em grafos muito grandes, que não podem ser armazenadas completamente na memória, a busca em profundidade não termina, em casos onde o comprimento de um caminho numa árvore de busca é infinito. O simples artifício de “ lembrar quais nós já foram visitados” não funciona, porque pode não haver memória suficiente. Isso pode ser resolvido estabelecendo-se um limite de aumento na profundidade da árvore.
Problemas que envolvem grafos
· Coloração de Grafos: o Teorema das quatro cores
· Conjuntos grafos
· Clique
· Problemas de Roteamento:
· Problema da inspeção de rotas (também conhecido como o "Problema do carteiro chinês")
· Problema do caixeiro viajante
· Teorema do mínimo corte-máximo fluxo
· Problemas de Isomorfismo (casamento de grafos)
· Rotulação canônica?
· Isomorfismo de subgrafos e monomorfismos
. Máximo subgrafo comum.
Algoritmos importantes
· algoritmo de Dijkstra
· algoritmo de Kruskal
· algoritmo do vizinho mais próximo
· algoritmo de Prim.
Generalizações:
Num hipergrafo uma aresta pode conectar mais que dois vértices.
Um grafo não-direcionado pode ser visto como um complexo simplicial consistindo de símplices de uma dimensão (as arestas) e símplices de dimensão zero (os vértices). Ou seja, complexos são generalizações de grafos que permitem símplices de maiores dimensões.
Referências
1. Biggs, N.; Lloyd, E. and Wilson, R. (1986), Graph Theory, 1736-1936, Oxford University Press
2. Ver exemplo
Ligações externas
O Commons possui multimídias sobre Teoria dos grafos
Em inglês
· Graph theory tutorial
· Graph theory algorithm presentation
· Some graph theory algorithm animations
· Step through the algorithm to understand it.
· The compendium of algorithm visualisation sites
· A search site for finding algorithm implementations, explanations and animations
· Graph Theory Software
Em português
· Material sobre grafos da USP São Carlos
· Uma Introdução Sucinta à Teoria dos Grafos
· Material com "Atlas de Grafos" da FINTEC
· Enumeração de caminhos - Algoritmo Grafos
Ferramentas de grafos populares
· http://www.graphviz.org/ (em inglês)
· http://www.absint.com/aisee/index_pt.htm (em português)
· http://www.aisee.com (em inglês)
· http://www.research.att.com/sw/tools/graphviz/ (em inglês)
· http://www.cs.uni-sb.de/RW/users/sander/html/gsvcg1.html (em inglês)
· http://www.tulip-software.org (em inglês)
· [1]
· [2]
Ver também
· Estrutura de dados árvore ordenada - DAGs, árvores binárias e outras formas especiais de grafos.
· Grafo
· Rede complexa
· Quiver
· Teoria espectral de grafos
· Lista de adjacência
Problema Prático: Algoritmo de Dijkstra: JOGO DOS ELOS MALUCOS (foi usado Heurística!)
Problema resolvido (IMPLEMENTADO) em Linguagem Pascal e o Programa Fonte aqui disponibilizado. Arquivo no Formato ""PDF"
Algoritmo de DIJKSTRA
- Heurística -
Ensino&Informação: Heurística trata de incluir na busca (caso Grafos) informações que se poderia dizer do tipo Valiosas com o objetivo de encontrar a solução mais rapidamente e a correta ... pode se dizer que é a tentativa de criar um ATALHO para se chegar ao "objetivo"!
Problema Prático: Algoritmo de Dijkstra: JOGO DO TABULEIRO (foram usadas 3 Heurísticas!)
Problema resolvido (IMPLEMENTADO) em Linguagem Pascal e o Programa Fonte aqui disponibilizado. Arquivo no Formato ""PDF"
Algoritmo de DIJKSTRA
- Heurística -
Ensino&Informação: Heurística trata de incluir na busca (caso Grafos) informações que se poderia dizer do tipo Valiosas com o objetivo de encontrar a solução mais rapidamente e a correta ... pode se dizer que é a tentativa de criar um ATALHO para se chegar ao "objetivo"!
1) Reoria dos Grafos
Veja a página em Slide
2) Teoria dos Grafos
Veja a página em Slide
3) Teoria dos Grafos
Veja a página em Slide
4) Teoria dos Grafos
Veja a página em Slide
Texto a ser Editado. Aguardem!
A partir de 06 Set de 2020
Você é o Visitante de Número