O que seria uma árvore e uma floresta? – terminologia estrutura-de-dados árvore

Pergunta:


Por vezes aqui, encontrei aqui no SO, perguntas sobre árvores, grafos e até florestas, nas mais diversas linguagens, mas

  • Em programação, o que seria uma árvore? E o que seria uma floresta? Seria uma evolução da árvore, ou um conjunto de árvores?
  • Qual a utilidade de ambas?
  • Elas poderiam ser comparadas a um array?

Talvez uma imagem ajude a compreender melhor este conceito.

Autor da pergunta UzumakiArtanis

Resposta Don’t Panic:

  • Em programação, o que seria uma árvore?

Na teoria dos grafos, uma árvore é um grafo conexo (existe caminho entre quaisquer dois de seus vértices) e acíclico (não possui ciclos). Seria o mesmo princípio da Árvore N-ária de Pesquisa ou Árvore Binária, porém na Árvore cada nó pode ter vários sucessores porém apenas 1 antecessor.

Veja o exemplo:

inserir a descrição da imagem aqui

É parecido com a Árvore Binária:

inserir a descrição da imagem aqui

  • E o que seria uma floresta?

Caso o grafo seja acíclico mas não conexo, ele é dito uma floresta. Na utilização de Prim e Kruskal, se você parar a execução de Kruskal na metade do algoritmo, você pode gerar uma floresta (sub-grafos não conexos), pois a árvore apenas é gerada no final da execução.

  • Qual a utilidade de ambas?

    Vamos supor que sua cidade precise economizar energia, e que sua cidade possui N ruas, sua função é descobrir quais ruas conseguiria desligar a energia, qual seria a quantidade mínima de ruas com o menor custo possível que precisariam estar ligadas? Isso seria uma utilização da Arvore Geradora mínima.

    Se você gerou uma Floresta ( várias árvores), provavelmente não há uma solução viável.

  • Elas poderiam ser comparadas a um array?

    Não, está parecido mais com uma Arvore N-Aria. Onde a posição atual possui um “ArrayList” de sucessores e o sucessor possui uma referência ao Pai.

Lendo esse material de Arvore de Pesquisa consegue verificar uma implementação básica da Árvore, porém é necessário fazer as adequações para a AGM.

Todos são estruturas de dados baseados em grafos. De grosso modo, um grafo é uma estrutura definida por um conjunto de pontos P e um conjunto de arestas A, onde um elemento a do conjunto A tem dois atributos, a.origem e a.destino, sendo que ambos a.origem e a.destino pertencem ao conjunto P.

Um grafo pode ser totalmente conectado (grafo conexo), ou ele pode ter partes totalmente independentes (grafo desconexo). Um grafo desconexo significa que existem pontos p1 e p2 tais que não é possível navegar de p1 e chegar em p2 pelas arestas definidas em A.

Uma árvore é um tipo de grafo conexo em que todo ponto seja destino de apenas uma única origem.

Uma floresta é um grafo possivelmente desconexo tal que, para cada unidade conexa, você tem uma árvore. Uma floresta conexa é uma árvore.


Como o @Everson comentou na pergunta, a explicação de grafos e árvores nesta resposta estão ótimas, incluindo até mesmo desenhos bem intuitivos.

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *