Escolar Documentos
Profissional Documentos
Cultura Documentos
Estruturas De Dados e
Algoritmos
Java
YANG HU
Aprenda fácil, rápido e bem.
http://br.verejava.com
Copyright © 2020 Yang Hu
All rights reserved.
ISBN: 9798651653744
CONTEÚDO
1. Definição de tabela linear
2. Anexar tabela linear
3. Inserção de mesa linear
4. Tabela linear Excluir
5. Algoritmo de Ordenar de bolhas
6. Selecione o algoritmo de Ordenar
7. Inserir algoritmo de Ordenar
8. Pesquisa de tabela linear
9. Algoritmo de pesquisa de dicotomia
10. Lista vinculada única
10.1 Criar e Inicialização
10.2 Adicionar nó
10.3 Inserir nó
10.4 Excluir nó
11. Lista duplamente vinculada
11.1 Criar e Inicialização
11.2 Adicionar nó
11.3 Inserir nó
11.4 Excluir nó
12. Lista vinculada circular unidirecional
12.1 Criar e Inicialização
12.2 Inserir nó
12.3 Excluir nó
13. Lista vinculada circular de duas vias
13.1 Criar e Inicialização
13.2 Inserir nó
13.3 Excluir nó
14. Fila
15. Pilha
16. Algoritmo Recursivo
17. Algoritmo de Ordenar rápida
18. Algoritmo de mesclagem bidirecional
19. Árvore de pesquisa binária
19.1 Construir uma árvore de pesquisa binária
19.2 Árvore de pesquisa binária In-order traversal
19.3 Árvore de pesquisa binária Pre-order traversal
19.4 Árvore de pesquisa binária Post-order
traversal
19.5 Árvore de pesquisa binária Máximo e mínimo
19.6 Árvore de pesquisa binária Excluir nó
20. Ordenar da pilha
21. Tabela de hash
22. Gráfico
22.1 Gráfico direcionado e pesquisa em
profundidade
22.2 Gráfico dirigido e Primeira pesquisa de
largura
22.3 Ordenar topológica
Definição de tabela linear
Tabela Linear (Linear Table): Uma sequência de zero ou mais elementos
de dados. Além do primeiro elemento, cada elemento possui apenas um
elemento precursor direto e cada elemento possui apenas um elemento
sucessor direto, exceto o último. A relação entre os elementos de dados é de
um para um. As tabelas lineares podem ser representadas por matrizes
unidimensionais.
TestOneArray.java
Análise:
1. Primeiro, crie uma matriz temporária (tempArray) maior que o
comprimento da matriz original
2. Copie cada valor da matriz para tempArray
3. Atribua 75 ao último índice de tempArray
4. Finalmente, atribua a referência do ponteiro tempArray à matriz
original;
TestOneArrayAdd.java
Resultado:
Análise:
1. Primeiro, crie uma matriz temporária tempArray maior que o
comprimento original da matriz
2. Do início à posição de inserção Copie cada valor do valor anterior da
matriz para tempArray
3. Mova a matriz da posição de inserção para cada valor do último elemento
e mova-o de volta para tempArray
4. insira 75 no tempArray.
5. Finalmente, atribua a referência do ponteiro tempArray à matriz original;
TestOneArrayInsert.java
Resultado:
Análise:
1. Crie uma matriz temporária tempArray com tamanho menor que a
matriz original.
2. Copie os dados na frente de i = 2 para a frente do tempArray
3. Copie a matriz após i = 2 para tempArray
4. Atribua a referência do ponteiro tempArray à matriz original
TestOneArrayRemove.java
Resultado:
90,70,80,60,85,
Algoritmo de Ordenar de bolhas
Algoritmo de Ordenar de bolhas (Bubble Sorting Algorithm):
se arrays [j]> arrays [j + 1] forem trocados. Os elementos restantes repetem
esse processo até a Ordenar ser concluída.
Sem Ordenar,
Comparando,
Já Ordenar
1. Primeira Ordenar:
2. Segunda Ordenar:
3. Terceira Ordenar:
sort(scores);
Resultado:
50,60,70,80,95,
Selecione o algoritmo de Ordenar
Selecione o algoritmo de Ordenar (Select Sorting Algorithm):
Classifica uma matriz localizando repetidamente o elemento mínimo de
uma parte não classificada e colocando-a no início.
Sem Ordenar,
Comparando,
Já Ordenar
1. Primeira Ordenar:
2. Segunda Ordenar:
3. Terceira Ordenar:
4. Quarta Ordenar:
}
}
Resultado:
50,60,70,80,95,
Inserir algoritmo de Ordenar
Inserir algoritmo de Ordenar (Insert Sorting Algorithm):
Pegue um novo elemento não classificado na matriz, compare-o com o
elemento já classificado antes, se o elemento for menor que o elemento
classificado, insira um novo elemento na posição correta.
Explicação:
Sem Ordenar,
Comparando,
Já Ordenar
1. Primeira Ordenar:
2. Segunda Ordenar:
3. Terceira Ordenar:
4 Quarta Ordenar:
TestInsertSort.java
sort(scores);
Resultado:
50,60,70,80,95,
Pesquisa de tabela linear
1. Digite 70 que deseja pesquisar e depois retorne o índice.
TestOneArraySearch.java
Resultado:
Found value: 70 the index is: 1
Algoritmo de pesquisa de dicotomia
Algoritmo de pesquisa de dicotomia (Dichotomy Search Algorithm):
O algoritmo de pesquisa binária, também conhecido como algoritmo de
pesquisa binária e algoritmo de pesquisa logarítmica, é um algoritmo de
pesquisa para encontrar um elemento específico em uma matriz ordenada.
O processo de pesquisa inicia no elemento do meio da matriz. Se o
elemento do meio for o elemento a ser encontrado, o processo de pesquisa
será encerrado; se um elemento em particular for maior que ou menor que o
elemento do meio, ele será encontrado na metade da matriz que é maior ou
menor que o elemento do meio, e Comece com o elemento do meio como
antes..
System.out.println("-----------------------------");
searchValue = 90;
position = binarySearch(scores, searchValue);
System.out.println(searchValue + " position:" + position);
}
}
Resultado:
40 position:1
-----------------------------
90 position:5
Lista vinculada única
Lista vinculada única (Single Linked List):
É uma estrutura de armazenamento encadeado de uma tabela linear, que é
conectada por um nó. Cada nó consiste em dados e ponteiro para o próximo
nó.
UML Diagrama
Node.java
return head;
}
}
2. Saída de lista vinculada única .
TestSingleLinkList.java
return head;
}
Resultado:
A -> B -> C -> D -> End
3. Anexe um novo nome de nó: E.
return head;
}
return head;
}
newNode.next = p.next;
p.next = newNode;
}
public static void print() {
Node p = head;
while (p != null) // Imprimir do início ao fim
{
System.out.print(p.data + " -> ");
p = p.next;
}
System.out.print("End\n\n");
}
print();
}
}
Resultado:
return head;
}
Resultado:
A -> B -> D -> End
UML Diagrama
Node.java
class Node {
private String data;
public Node prev;
public Node next;
p = end;
while (p != null) //Imprimir do início ao fim
{
String data = p.getData();
System.out.print(data + " -> ");
p = p.prev;
}
System.out.print("Start\n\n");
}
Resultado:
A -> B -> C -> D -> End
p = end;
while (p != null) // Imprimir do início ao fim
{
String data = p.getData();
System.out.print(data + " -> ");
p = p.prev;
}
System.out.print("Start\n\n");
}
p = end;
while (p != null) // Imprimir do início ao fim
{
String data = p.getData();
System.out.print(data + " -> ");
p = p.prev;
}
System.out.print("Start\n\n");
}
p = end;
while (p != null) // Imprimir do início ao fim
{
String data = p.getData();
System.out.print(data + " -> ");
p = p.prev;
}
System.out.print("Start\n\n");
}
UML Diagrama
Node.java
Resultado:
A -> B -> E -> C -> D -> A
4. Exclua o índice = 2 nós.
TestSingleCircleLink.java
Resultado:
A -> B -> D -> A
Lista vinculada circular de duas vias
Lista vinculada circular de duas vias (Two-way Circular List):
É uma estrutura de armazenamento em cadeia de uma tabela linear. Os nós
são conectados em série por duas direções e são conectados para formar um
anel. Cada nó é composto de dados, apontando para o nó anterior e
apontando para o próximo nó.
UML Diagrama
Node.java
class Node {
private String data;
public Node prev;
public Node next;
p = tail;
do {// Imprimir do início ao fim
data = p.getData();
System.out.print(data + " -> ");
p = p.prev;
} while (p != tail);
data = p.getData();
System.out.print(data + "\n\n");
}
p = tail;
do {// Imprimir do início ao fim
data = p.getData();
System.out.print(data + " -> ");
p = p.prev;
} while (p != tail);
data = p.getData();
System.out.print(data + "\n\n");
}
p = tail;
do {// Imprimir do início ao fim
data = p.getData();
System.out.print(data + " -> ");
p = p.prev;
} while (p != tail);
data = p.getData();
System.out.print(data + "\n\n");
}
UML Diagrama
Node.java
class Node {
private String data;
public Node next;
public Node prev;
head = head.prev;
p.next = null;
p.prev = null;
size--;
return p;
}
public int size() {
return size;
}
}
TestQueue.java
print(queue);
}
Resultado:
Head A <- B <- C <- D <- Tail
Pilha
Pilha (Stack): Stack é uma estrutura de dados linear que segue uma ordem
particular na qual as operações são realizadas. O pedido pode ser LIFO
(Last In First Out).
UML Diagrama
Node.java
class Node {
public String data;
public Node next;
Node p = top;
top = top.next;// ponteiro superior mover para baixo
p.next = null;
size--;
return p;
}
print(stack);
}
Resultado:
Resultado:
array[i] = threshold;
quickSort(array, low, i - 1); // esquerda rápida Classificar
quickSort(array, i + 1, high); // Ordenar rápida à direita
}
quickSort(scores);
Resultado:
50,60,70,80,90,100
Algoritmo de mesclagem bidirecional
Algoritmo de mesclagem bidirecional (Two-way Merge Algorithm):
Os dados da primeira metade e da segunda metade são classificados e as
duas sub-listas ordenadas são mescladas em uma lista ordenada, que
continua recursiva até o final.
mergeSort(scores);
private static void mergeSort(int[] array, int[] temp, int left, int right)
{
Resultado:
50,63,65,74,76,87,99,100
Árvore de pesquisa binária
Árvore de pesquisa binária (Binary Search Tree):
1. Se a subárvore esquerda de qualquer nó não estiver vazia, o valor de
todos os nós na subárvore esquerda será menor que o valor do nó raiz;
2. Se a subárvore direita de qualquer nó não estiver vazia, o valor de todos
os nós na subárvore direita será maior que o valor do nó raiz;
3. A subárvore esquerda e a subárvore direita de qualquer nó também são
árvores de pesquisa binária.
UML Diagrama
Node.java
public Node() {
}
}
1. Construir uma árvore de pesquisa binária
Os nós inseridos são comparados a partir do nó raiz e o menor que o nó raiz
é comparado com a subárvore esquerda do nó raiz, caso contrário,
comparado com a subárvore direita até que a subárvore esquerda esteja
vazia ou a subárvore direita esteja vazia, será inserido.
Inserir 60
Inserir 40
Inserir 20
Inserir 10
Inserir 30
Inserir 50
Inserir 80
Inserir 70
Inserir 90
2. á rvore de pesquisa binária In-order traversal
In-order traversal : left subtree -> root node -> right subtree
Resultado:
BinaryTree.java
Resultado:
In-order traversal binary search tree
10, 20, 30, 40, 50, 60, 70, 80, 90,
3. árvore de pesquisa binária Pre-order traversal
Pre-order traversal : root node -> left subtree -> right subtree
Resultado:
BinaryTree.java
Resultado:
Pre-order traversal binary search tree
60, 40, 20, 10, 30, 50, 80, 70, 90,
4. á rvore de pesquisa binária Post-order traversal
Post-order traversal : right subtree -> root node -> left subtree
Resultado:
BinaryTree.java
Resultado:
Post-order traversal binary search tree
10, 30, 20, 50, 40, 70, 90, 80, 60,
5. á rvore de pesquisa binária Máximo e mínimo
Mínimo: O valor pequeno está no nó filho esquerdo, desde que a recursão
atravesse o filho esquerdo até ficar vazio, o nó atual é o nó mínimo.
Máximo: O valor grande está no nó filho certo, desde que o percurso
recursivo seja o filho certo até ficar vazio, o nó atual é o maior nó.
BinaryTree.java
}
TestBinaryTree.java
System.out.println("\nMinimum Value");
Node minNode=binaryTree.searchMinValue(binaryTree.getRoot());
System.out.println(minNode.getData());
System.out.println("\nMaximum Value");
Node maxNode=binaryTree.searchMaxValue(binaryTree.getRoot());
System.out.println(maxNode.getData());
}
}
Resultado:
Minimum Value
10
Maximum Value
90
6. árvore de pesquisa binária Delete Node
System.out.println("\n--------------------------------------------");
System.out.println("\n--------------------------------------------");
Ordenar da pilha:
1. Construa uma pilha
2. Após a saída do elemento superior do heap, ajuste de cima para baixo,
compare o elemento superior com o nó raiz de suas subárvores esquerda e
direita e troque o menor elemento pela parte superior do heap; depois ajuste
continuamente até os nós das folhas para obter novo heap.
1. {10, 90, 20, 80, 30, 70, 40, 60, 50} construir heap e, em seguida, heap
classificar saída.
// Inicialize o heap
public void createHeap(int[] array) {
this.array = array;
// Ajustar pilha
public void adjustHeap(int currentIndex, int maxLength) {
int noLeafValue = array[currentIndex];
int[] scores = { 10, 90, 20, 80, 30, 70, 40, 60, 50 };
////////////////////////////////////////////////////////////
System.out.println("After building a heap : ");
heapSort.createHeap(scores);
for (int i = 0; i < scores.length; i++) {
System.out.print(scores[i] + ", ");
}
System.out.print("\n\n");
////////////////////////////////////////////////////////////
System.out.println("After heap sorting : ");
heapSort.heapSort();
for (int i = 0; i < scores.length; i++) {
System.out.print(scores[i] + ", ");
}
}
}
Resultado:
Before building a heap :
10 , 90 , 20 , 80 , 30 , 70 , 40 , 60 , 50 ,
Node.java
public class Node {
private Object key;
private Object value;
private int hash;
public Node next;
public Hashtable() {
table = new Node[capacity];
}
newNode.next = table[hash];
table[hash] = newNode;
size++;
}
return null;
}
}
TestHashtable.java
Resultado:
david => Good Boy Keep Going
grace => Cute Girl Keep Going
Gráfico direcionado e pesquisa em
profundidade
Gráfico direcionado (Directed Graph):
A estrutura de dados é representada por uma matriz de adjacência (ou seja,
uma matriz bidimensional) e uma lista de adjacência. Cada nó é chamado
de vértice (vertex) e dois nós adjacentes são chamados de arestas (edge).
1. matriz de adjacência:
O número total de vértices é um tamanho de matriz bidimensional, se
houver aresta de valor 1, caso contrário, aresta é 0.
2. Primeira pesquisa de profundidade:
Procure o nó de borda vizinho B de A e, em seguida, encontre o nó vizinho
C de B e assim por diante até que todos os nós sejam encontrados A -> B ->
C -> D -> E.
Vertex.java
public Vertex() {
super();
}
}
Graph.java
import java.util.Stack;
while (!stack.isEmpty()) {
int row = stack.peek();
// Obter posições de vértice adjacentes que não foram visitadas
int col = findAdjacencyUnVisitedVertex(row);
if (col == -1) {
stack.pop();
} else {
vertexs[col].setVisited(true);
System.out.print(" -> "+vertexs[col].getData());
stack.push(col);
}
}
clear();
}
return -1;
}
TestGraph.java
public class TestGraph {
public static void printGraph(Graph graph) {
for (int i = 0; i < graph.getVertexs().length; i++) {
System.out.print(graph.getVertexs()[i].getData() + " ");
}
System.out.print("\n");
graph.addEdge(0, 1);
graph.addEdge(0, 2);
graph.addEdge(0, 3);
graph.addEdge(1, 2);
graph.addEdge(1, 3);
graph.addEdge(2, 3);
graph.addEdge(3, 4);
printGraph(graph);
graph.depthFirstSearch();
}
}
Resultado:
A B C D E
A0 1 1 1 0
B0 0 1 1 0
C0 0 0 1 0
D0 0 0 0 1
E0 0 0 0 0
Depth-first search traversal output :A -> B -> C -> D -> E
Gráfico dirigido e Primeira pesquisa
de largura
Primeira pesquisa de largura (Breadth-First Search):
Encontre todos os nós de borda vizinhos B, C, D de A e, em seguida,
encontre todos os nós vizinhos A, C, D de B e assim por diante até que
todos os nós sejam encontrados A -> B -> C -> D -> E.
Vertex.java
public Vertex() {
super();
}
}
Graph.java
import java.util.LinkedList;
import java.util.Queue;
int col;
while (!queue.isEmpty()) {
int head = queue.remove();
TestGraph.java
public class TestGraph {
public static void printGraph(Graph graph) {
for (int i = 0; i < graph.getVertexs().length; i++) {
System.out.print(graph.getVertexs()[i].getData() + " ");
}
System.out.print("\n");
graph.addEdge(0, 1);
graph.addEdge(0, 2);
graph.addEdge(0, 3);
graph.addEdge(1, 2);
graph.addEdge(1, 3);
graph.addEdge(2, 3);
graph.addEdge(3, 4);
printGraph(graph);
graph.breadthFirstSearch();
}
}
Resultado:
A B C D E
A0 1 1 1 0
B0 0 1 1 0
C0 0 0 1 0
D0 0 0 0 1
E0 0 0 0 0
Breadth-First Search traversal output :A -> B -> C -> D -> E
Ordenar topológica
Ordenar topológica (Topological Sorting):
Classifique os vértices no gráfico direcionado com a ordem de direção
.
O gráfico direcionado tem direção : A -> B e B -> A são diferentes
1. matriz de adjacência:
O número total de vértices é um tamanho de matriz bidimensional, se
houver aresta de valor 1, caso contrário, aresta é 0.
Ordenar topológica a partir do vértice A : A -> B -> C -> D -> E
Vertex.java
public Vertex() {
super();
}
}
Graph.java
for (int col = vertex; col < size - 1; col++) {// Mova uma linha
para a esquerda
for (int row = 0; row < size - 1; row++) {
adjacencyMatrix[row][col] = adjacencyMatrix[row][col + 1];
}
}
}
size--;// Diminuir o número de vértices
}
graph.addVertex("A");
graph.addVertex("B");
graph.addVertex("C");
graph.addVertex("D");
graph.addVertex("E");
graph.addEdge(0, 1);
graph.addEdge(0, 2);
graph.addEdge(0, 3);
graph.addEdge(1, 2);
graph.addEdge(1, 3);
graph.addEdge(2, 3);
graph.addEdge(3, 4);
printGraph(graph);
graph.topologySort();
Resultado:
Two-dimensional array traversal output vertex edge and adjacent array :
A B C D E
A0 1 1 1 0
B0 0 1 1 0
C0 0 0 1 0
D0 0 0 0 1
E0 0 0 0 0