Árvore 2-3-4Em ciência da computação, uma árvore 2-3-4 (também chamada árvore 2-4) é uma estrutura de dados auto-balanceada, comumente usada para implementar dicionários.[carece de fontes] Os números significam uma árvore onde cada nó pai (nó interno) tem dois, três, ou quatro nós filhos:
Árvores 2-3-4 são árvores B de ordem 4;[1] assim como árvores B em geral, eles podem pesquisar, inserir e excluir em tempo O(log n). Uma propriedade de uma árvore 2-3-4 é que todos os nós externos estão na mesma profundidade. Árvores 2-3-4 são uma isometria de árvores rubro-negras, o que significa que eles são estruturas de dados equivalentes. Em outras palavras, para cada árvore 2-3-4, existe pelo menos uma árvore rubro-negra com elementos na mesma ordem. Além disso, as inserções e exclusões em árvores 2-3-4 que causam expansões, splits e merges são equivalentes as rotações baseadas em cores das árvores rubro-negras. Introduções ás árvores rubro-negras geralmente usam árvores 2-3-4 primeiro, porque eles são conceitualmente mais simples. Árvores 2-3-4, no entanto, podem ser difíceis de implementar na maioria das linguagens de programação, devido ao grande número de casos especiais envolvidos nas operações desta árvore. Árvores rubro-negras são mais simples de implementar,[2] por isso tendem a ser usadas em vez disso. Propriedades
InserçãoPara inserir um valor, começamos da raiz da árvore 2-3-4:
ExemploPara inserir o valor "25" para esta árvore 2-3-4:
RemoçãoConsidere a possibilidade de deixar apenas o elemento lá, marcando-o como "excluído", possivelmente para ser reusado em uma futura inserção. Para remover um valor a partir da árvore 2-3-4:
Faça os seguintes ajustes, quando um 2-nó – exceto o nó raiz – é encontrado no caminho para a folha que desejamos remover:
Uma vez que o valor procurado é atingido, ele pode agora ser colocado na entrada do local removido sem nenhum problema, porque garante-se que o nó folha tenha mais que 1 chave. Remoção em uma árvore 2-3-4 é O(n log n), supondo que a transferência e fusão executam em tempo constante O(1).[5] Exemplo de código fontepublic class TwoThreeFourTree {
private Node root;
private class Node {
private int[] keys = new int[3];
private Node[] children = new Node[4];
private int numKeys;
public int getNumKeys() {
return numKeys;
}
public int getKey(int index) {
return keys[index];
}
public Node getChild(int index) {
return children[index];
}
public void setChild(int index, Node child) {
children[index] = child;
}
public boolean isLeaf() {
return children[0] == null;
}
public void insertNonFull(int key) {
int i = numKeys - 1;
if (isLeaf()) {
while (i >= 0 && keys[i] > key) {
keys[i + 1] = keys[i];
i--;
}
keys[i + 1] = key;
numKeys++;
} else {
while (i >= 0 && keys[i] > key) {
i--;
}
if (children[i + 1].getNumKeys() == 3) {
splitChild(i + 1, children[i + 1]);
if (keys[i + 1] < key) {
i++;
}
}
children[i + 1].insertNonFull(key);
}
}
public void splitChild(int index, Node node) {
Node newNode = new Node();
newNode.numKeys = 1;
newNode.keys[0] = node.keys[2];
newNode.children[0] = node.children[2];
newNode.children[1] = node.children[3];
node.numKeys = 1;
for (int j = numKeys; j >= index + 1; j--) {
children[j + 1] = children[j];
keys[j] = keys[j - 1];
}
children[index + 1] = newNode;
keys[index] = node.keys[1];
numKeys++;
}
public Node search(int key) {
int i = 0;
while (i < numKeys && key > keys[i]) {
i++;
}
if (keys[i] == key) {
return this;
}
if (isLeaf()) {
return null;
}
return children[i].search(key);
}
public void traverse() {
for (int i = 0; i < numKeys; i++) {
if (!isLeaf()) {
children[i].traverse();
}
System.out.print(keys[i] + " ");
}
if (!isLeaf()) {
children[numKeys].traverse();
}
}
}
public TwoThreeFourTree() {
root = new Node();
}
public Node search(int key) {
return root.search(key);
}
public void insert(int key) {
if (root.getNumKeys() == 3) {
Node newRoot = new Node();
newRoot.children[0] = root;
root = newRoot;
newRoot.splitChild(0, root);
newRoot.insertNonFull(key);
} else {
root.insertNonFull(key);
}
}
public void traverse() {
root.traverse();
}
public static void main(String[] args) {
Tree234<Integer> tree = new Tree234<Integer>();
// Inserção de valores na árvore
tree.insert(50);
tree.insert(25);
tree.insert(75);
tree.insert(12);
tree.insert(37);
tree.insert(62);
tree.insert(87);
tree.insert(6);
tree.insert(18);
tree.insert(31);
tree.insert(43);
tree.insert(56);
tree.insert(68);
tree.insert(81);
tree.insert(93);
// Impressão dos valores na ordem da árvore
System.out.println("Valores na ordem da árvore: ");
tree.displayTree();
// Busca de valores na árvore
int key = 43;
Node<Integer> found = tree.find(key);
if (found != null) {
System.out.println("Valor " + key + " encontrado na árvore.");
} else {
System.out.println("Valor " + key + " não encontrado na árvore.");
}
key = 100;
found = tree.find(key);
if (found != null) {
System.out.println("Valor " + key + " encontrado na árvore.");
} else {
System.out.println("Valor " + key + " não encontrado na árvore.");
}
// Remoção de valores da árvore
key = 75;
boolean removed = tree.remove(key);
if (removed) {
System.out.println("Valor " + key + " removido da árvore.");
System.out.println("Valores na ordem da árvore após remoção: ");
tree.displayTree();
} else {
System.out.println("Valor " + key + " não encontrado na árvore.");
}
key = 100;
removed = tree.remove(key);
if (removed) {
System.out.println("Valor " + key + " removido da árvore.");
System.out.println("Valores na ordem da árvore após remoção: ");
tree.displayTree();
} else {
System.out.println("Valor " + key + " não encontrado na árvore.");
}
}
Ver tambémReferências
Ligações externas |
Portal di Ensiklopedia Dunia