exerc cios paa grafos n.
Download
Skip this Video
Loading SlideShow in 5 Seconds..
Exercícios PAA- Grafos PowerPoint Presentation
Download Presentation
Exercícios PAA- Grafos

Loading in 2 Seconds...

play fullscreen
1 / 37

Exercícios PAA- Grafos - PowerPoint PPT Presentation


  • 77 Views
  • Uploaded on

Exercícios PAA- Grafos. Eduardo Laber. Exercício de Implementação. 1. Modifique o código da BFS para que esta preencha um vetor d com n entradas aonde d (u) é a distância da origem s até o vértice u. for every vertex v of G not explored yet d(v)  infinito End For 2 d(s)  0

loader
I am the owner, or an agent authorized to act on behalf of the owner, of the copyrighted work described.
capcha
Download Presentation

PowerPoint Slideshow about 'Exercícios PAA- Grafos' - caelan


An Image/Link below is provided (as is) to download presentation

Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author.While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server.


- - - - - - - - - - - - - - - - - - - - - - - - - - E N D - - - - - - - - - - - - - - - - - - - - - - - - - -
Presentation Transcript
exerc cio de implementa o
Exercício de Implementação
  • 1. Modifique o código da BFS para que esta preencha um vetor d com n entradas aonde d(u) é a distância da origem s até o vértice u.
  • for every vertex v of G not explored yet
  • d(v) infinito
  • End For
  • 2 d(s)  0
  • 3 mark vertex s as visited
  • 4 whileS is not empty do
  • 5u← Dequeue(S);
  • 6For each v in Adj[u] then
  • 7if v is unexplored then
  • 8 mark vertex v as visited
  • 9 d(v)  d(u)+1
  • 10Enqueue(S,v)
cap 3 tardos
Cap 3-Tardos

Exercício 2

  • Modifique o pseudo-código da busca em profundidade da seguinte forma.
  • Ao visitar um vértice v a partir de u
    • Se v não foi visitado faça
      • upai (v)
    • Se v já foi visitado
      • Se v<> pai(u)
        • Ciclo existe (uv+ caminho de u a v na árvore)
cap 3 tardos1
Cap 3-Tardos

Exercicio 2: Ciclo em grafo direcionado

  • Execute uma busca em profundidade no grafo anotando, para cada vértice v,
    • o pai de v
    • o momento que a busca em v começa: pre(v)
    • o momento que a busca em v termina: pos(v)
  • Ao tentar visitar um vértice v a partir de u tal que a busca em v já começou mais ainda não terminou (pos(v) =-1) podemos obter um ciclo da seguinte forma.
    • Caminhe pelos pais de u até encontrar v. O ciclo é formado por este caminho + o arco (u,v)
cap 3 tardos2
Cap 3-Tardos

Exercício 3

  • Execute uma ordenação topológica no Grafo. Se em algum ponto não houver uma fonte, quer dizer que o grafo contém ciclos.
  • Execute o algoritmo do slide anterior
cap 3 tardos3
Cap 3-Tardos

Exercício 4

  • Etapa 1. Construa o grafo G[S] induzido pelas arestas do conjunto S. Utilize uma DFS(BFS) para determinar as componentes conexas deste grafo. Atribua o número da componente para cada vértice (borboleta).
  • Etapa 2. Crie um novo grafo H=(V’,E’), onde V’={componentes conexas de G[S]} e o conjunto E’ é obtido da seguinte forma: para cada aresta e=(i,j) em D adicione uma aresta entre os vértices que correspondem as componente de i e de j.
  • A hipótese de dois grupos é consistente se e somente se H é um grafo bipartido. Note que grafos com laços não são bipartidos
cap 3 tardos4
Cap 3-Tardos

Exercício 7

  • Seja v um nó do grafo. Se u não é vizinho de v então existe um nó, digamos w, que é vizinho de u e de v. Caso contrário o grafo teria mais de n vértices (n/2 vizinhos de u, n/2 outros vizinhos de v, u e v). Contradição
  • Portanto, vwu é um caminho de v para u
cap 3 tardos5
Cap 3-Tardos

Exercício 8

  • Para um contra exemplo considere uma clique K com n- n0.5 e um único vértice desta clique ligado a um caminho de n0.5 vértices.
cap 3 tardos6
Cap 3-Tardos

Exercício 9

  • Considerar a árvore gerada a partir de uma busca em largura começando em s.
    • Como a altura desta árvore é maior que n/2 então existe um nível nesta árvore ( > 1 e < nível t) com apenas um nó.
    • Como toda aresta de G liga vértices da mesma camada ou de camadas adjacentes, ao remover este vértice desconectamos o grafo.
cap 3 tardos7
Cap 3-Tardos

Exercício 9

  • Algoritmo
    • Faça uma busca em largura calculando a distância de s a cada nó e preencha um vetor (de listas) indicando, na posição i, os vértices que distam i de s. Retorne o primeiro nó diferente de s que se encontra sozinho em uma lista
cap 3 tardos8
Cap 3-Tardos

Exercício 10

  • Utilizar uma busca em largura para decompor a árvore em camadas. Marcar para cada nó u a sua distância ao nó de origem v.
  • Em uma segunda passada acumular em cada nó u um contador num(u) indicando o número de caminhos de v a u.
    • Inicialmente os contadores são 0, exceto Num(v)=1.
    • Ao tentar visitar um nó y, com d(y)=i+1, a partir de um nó x, com d(x)=i, fazer

num(y) num(y)+num(x)

cap 3 tardos9
Cap 3-Tardos

Exercício 11

  • Construir um grafo não direcionado para cada tempo t (podem existir várias entradas associadas ao mesmo t)
  • Se existe um vertice em comum entre uma componente C do tempo t e uma componente C’ em t’, com t’>t, ligar aresta de C para C’.
  • Remover aresta entre C e C’ se a remocao da aresta permite que C’ seja alcancada a partir de C. Permite diminuir o tamanho do grafo
cap 3 tardos10
Cap 3-Tardos

Exercício 11

  • Construir um grafo não direcionado para cada tempo t. Ligamos duas conexões se elas tem arestas em comum.
  • Ligar o nó (a,b,t) ao nó (a,c,t’) se t’ é o menor instante maior que t tal que o nó a se conecta com alguem. Da mesma forma ligar (a,b,t) ao nó (a,b,t’) se t’ é o menor instante maior que t tal que o nó b se conecta
cap 3 tardos11
Cap 3-Tardos

Exercício 11

  • Fazer DFS a partir do primeiro vértice associado a C(a) a partir do tempo x e verificar se algum vertice correspondente a C(b) e alcancado antes de y
cap 3 tardos12
Cap 3-Tardos

Exercício 11

  • Manter um vetor de bits indicando se um programa foi infectado ou não
  • Construir um grafo não direcionado para cada tempo t e processar os grafos em ordem crescente de tempo
  • Processamento do grafo correspondente ao tempo t
    • De duas passadas no grafo
      • A primeira para marcar as componentes que tem um computador infectado e a segunda para marcar todos os computadores da componente como infectados.
cap 3 tardos13
Cap 3-Tardos

Exercício 12

Construa um grafo direcionados G da seguinte forma

a) Para cada pessoa P(i) crie dois vértices: B(i) – data de nascimento e D(i), data de morte

b) Para todo i, crie uma arco de B(i) para D(i)

c) Se nos dados coletados, P(i) morre antes de P(j) nascer crie um arco de D(i) para B(j)

d) Se nos dados coletados, a vida de P(i) tem interseção com a vida de P(j), crie um arco de P(i) para B(j) e um arco de B(i) para P(j)

Se G tem uma ordenação topológica os dados são consistentes, caso contrário não

dasgupta cap 3
Dasgupta-Cap 3

Exercício 8

  • Criamos 11*8*5=440 nós e associamos cada nó do grafo a uma tripla (a,b,c) correspondendo a quantidade de água em cada um dos recipientes.
  • . Existe uma aresta direcionado de um nó para outro se for possivel de um estado alcancar o outro com um movimento.
dasgupta cap 31
Dasgupta-Cap 3

Exercício 8

  • Cada nó pode ter 6 arestas partindo dele, logo o número de arestas é no máximo 2640
dasgupta cap 32
Dasgupta-Cap 3

Exercício 8

Basta executar uma BFS(DFS) no grafo começando no estado (0,7,4) e verificar se o estado (0,0,0) e alcançável

dasgupta cap 33
Dasgupta-Cap 3

Exercício 9

  • Duas passadas completas na lista de adjacência do grafo
    • A primeira passada calcula o grau de cada vértice
      • For each v in Adj[u]
        • degree(u)  degree(u)+1
    • Na segunda, acumulamos em twodegree[u], para cada u, a soma dos graus dos vizinhos de u.
      • For each v in Adj[u]
        • Twodegree[u]  Twodegree[u]+d(v)
dasgupta cap 34
Dasgupta-Cap 3

Exercício 13

a) Defina um vértice s em G e execute uma DFS a partir de s. Seja T a árvore obtida. Qualquer folha de T satisfaz a propriedade desejada

b) Qualquer Ciclo direcionado

c) G= dois ciclos disjuntos

dasgupta cap 35
Dasgupta-Cap 3

Exercício 15

  • Seja G=(V,E) o grafo direcionado em que V é o conjunto de interseções de ruas e E representa o conjunto das ruas
  • Verifique se o grafo é fortemente conexo utilizando o algoritmo ensinado em sala com complexidade O(m+n)
dasgupta cap 36
Dasgupta-Cap 3

Exercício 15

  • Seja v o nó correspondente a Town Hall. Seja S o conjunto de nó alcançáveis a partir de v. S pode ser obtido em O(m+n) através de uma DFS( BFS).

Seja G’ o grafo reverso de G. Seja T o conjunto de nós obtidos a partir de v em G’. Se S for um subconjunto de T então a propriedade é verdadeira. Caso contrário, é falsa. Podemos testar se S e subconjunto de T em O(n)

dasgupta cap 37
Dasgupta-Cap 3

Exercício 18

  • Execute uma DFS em G a partir de r e armazene os contadores pre e post para cada vértice do grafo.
  • u é ancestral de v se e somente se

pre[u] <pre[v]< post[v]<post[u]

dasgupta cap 38
Dasgupta-Cap 3

Exercício 22

  • Execute uma DFS em G e armazene o contador post para cada vértice do grafo. Seja v o vértice com maior post. Sabemos que ele pertence a um source node em G~ (aula de componentes fortemente conexos).
  • Execute uma DFS começando em v. Se apenas uma árvore for gerada então existe o nó desejado. Caso contrário, não.
dasgupta cap 39
Dasgupta-Cap 3

Exercício 24

Execute o algoritmo linear para ordenação topológica.

  • Se em algum ponto o conjunto S dos vértices com grau de entrada igual a 0 tiver mais de um elemento, então G não possui o caminho desejado. Caso contrário, ordem topológica é o caminho desejado.
exercicio resolvido
Exercicio Resolvido
  • Problema
  • Seja um grafo G=(V,E) representando a planta de um edifício. Inicialmente temos dois robos localizados em dois vértices de V, a e b, que devem alcançar os vértices c e d de V.
  • A cada passo um dos robos deve caminhar para um vértice adjacente ao vértice que ele se encontra no momento.
  • Exiba um algoritmo polinomial que decida se é possível, ou não, os robos partirem de a e b e chegarem em c e d, respectivamente, sem que em nenhum momento eles estejam a distância menor do que r, onde r é um inteiro dado.
exercicio resolvido1
Exercicio Resolvido
  • Solução
  • Seja H um grafo representando as configurações possíveis (posições dos robos) do problema. Cada nó de H corresponde a um par ordenado de vértices de V cuja distância menor ou igual a r.
  • Um par de nós u e v de H tem uma aresta se e somente em um passo é possível alcançar a configuração v a partir da configuração u em um único passo, ou seja, se u=(u1,u2) e v=(v1,v2) então uma das alternativas é válida
  • (i) u1=v1 e (u2,v2) pertence a E
  • (i) u2=v2 e (u1,v1) pertence a E
  • O problema portanto consiste em decidir se existe um camìnho entre o nó (a,b) e o nó (c,d) em H. Isso requer tempo linear no tamanho de H. Como H tem O(n2) vértices e O(n3) arestas, o algoritmo executa em O(n3) .
dasgupta cap 4 exerc cio 11
Dasgupta, Cap 4 -Exercício 11
  • Execute Dijkstra a partir de cada vértice v. O(|V|3)
  • Guarde em uma tabela Dist a menor distância Dist(u,v) entre u e v para cada para u,v
  • Procure na tabela Dist o par de vértices u,v que minimiza Dist(u,v)+Dist(v,u). Se o mínimo é infinito então o grafo é acíclico
    • O(|V|3), já que temos que considerar todos os pares
dasgupta cap 4 exerc cio 12
Dasgupta, Cap 4 -Exercício 12
  • Seja e=(u,v)
  • Remova a aresta e de G
    • O(|V|)
  • Execute Dijkstra para encontrar o caminho P de custo mínimo entre v e u em G-e.
    • O(|V|2), utilizando vetor como fila de prioridades
  • O ciclo é dado pela união de P com e.
dasgupta cap 4 exerc cio 14
Dasgupta, Cap 4 -Exercício 14

1. Execute Dijkstra para encontrar o caminho de custo mínimo entre v0 e os demais vertices em G

2. Execute Dijkstra para encontrar o caminho de custo mínimo entre v0 e os demais vertices em GR (grafo reverso)

3. O caminho mínimo entre u e w passando por vo é o caminho mínimo entre u e v0 e vo e w

dasgupta cap 4 exerc cio 17 a
Dasgupta, Cap 4 -Exercício 17.a
  • Utilize um vetor de nW posições como fila de prioridade.
  • A posição i do vetor deve guardar os nós v tal que o custo π(v) do menor caminho da origem s até v é i.
dasgupta cap 4 exerc cio 17 a1
Dasgupta, Cap 4 -Exercício 17.a
  • Portanto, encontrar o custo total de encontrar o vértice com menor valor π() requer O(nW) operações
    • Se o ultimo vértice colocado em S foi u então a busca pelo menor valor de π() deve ser feita a partir de π(u).
  • As atualizações podem ser feitas em O(E)
dasgupta cap 310
Dasgupta-Cap 3

Exercício 16

Execute uma ordem topologica e atribua o mesmo numero a todos os nos com grau 0 e remova eles do grafo.

Isso e o numero minimo?

O grafo e um DAG, execute o algoritmo do caminho mais longo.

dasgupta cap 311
Dasgupta-Cap 3

Exercício 17

b) Verificar se alguma componente fortemente conexa tem pelo menos 2 vertices

c) Verificar se algum no de V_G esta em alguma componente fortemente conexa com no pelo menos 2 vertices

d) Para cada CFC com pelo menos dois vertices, verifique se a remocao dos veritces de V_B mante a componente fortemente conexa.

dasgupta cap 312
Dasgupta-Cap 3

Exercício 17

b) Para cada CFC C com pelo menos dois vertices, verifique se alguma CFC do grafo induzido por C- V_B contem dois vertice de V_G. Se tiver, basta alcancar um destes vertices e ficar caminhando dentro desta componente infinitamente.