-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patharvoreBinaria.c
87 lines (75 loc) · 1.79 KB
/
arvoreBinaria.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#include <stdio.h>
#include <stdlib.h>
typedef struct no {
int dado;
struct no *esq, *dir;
} no;
void preordem (no *raiz) {
if (raiz != NULL) {
printf ("%d ", raiz->dado);
preordem (raiz->esq);
preordem (raiz->dir);
}
}
void emordem (no *raiz) {
if (raiz != NULL) {
emordem (raiz->esq);
printf ("%d ", raiz->dado);
emordem (raiz->dir);
}
}
void posordem (no *raiz) {
if (raiz != NULL) {
posordem (raiz->esq);
posordem (raiz->dir);
printf ("%d ", raiz->dado);
}
}
no *criar_arvore (int x, no *esq, no *dir) {
no *raiz = malloc (sizeof (no));
raiz->dado = x;
raiz->esq = esq;
raiz->dir = dir;
return raiz;
}
no *procurar (no *raiz, int x) {
if (raiz == NULL || raiz->dado == x) return raiz;
no *esq = procurar (raiz->esq, x);
if (esq != NULL) return esq;
return procurar (raiz->dir, x);
}
void inserir (no *raiz, int x, int y, char L) {
// inserir x do lado L de y
no *procurado = procurar (raiz, y);
if (L == 'E') {
no *novo = criar_arvore (x, procurado->esq, NULL);
procurado->esq = novo;
}
else {
no *novo = criar_arvore (x, NULL, procurado->dir);
procurado->dir = novo;
}
}
int main () {
int elem, novo;
char lado;
scanf ("%d", &novo);
no *raiz = criar_arvore (novo, NULL, NULL);
inserir(raiz, 3, 4, 'E');
inserir(raiz, 1, 3, 'E');
inserir(raiz, 10, 1, 'E');
inserir(raiz, 8, 3, 'D');
inserir(raiz, 5, 4 , 'D');
inserir(raiz, 2, 5, 'E');
inserir(raiz, 7, 5 , 'D');
printf ("Pre-ordem: ");
preordem (raiz);
printf ("\n");
printf (" Em-ordem: ");
emordem (raiz);
printf ("\n");
printf ("Pos-ordem: ");
posordem (raiz);
printf ("\n");
return 0;
}