Advertisement
Gabriel_Rofl

tree.c updated

Nov 16th, 2017
95
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.50 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include "tree.h"
  4.  
  5.  
  6. tree* cria_no(int dado){
  7.  
  8.     tree* x = malloc(sizeof(tree));
  9.  
  10.     x->data = dado;
  11.  
  12.     x->left = NULL;
  13.  
  14.     x->right = NULL;
  15.  
  16.     return(x);
  17. }
  18.  
  19. tree* inseri_na_arvore(tree* raiz, int dado){
  20.  
  21.     if(raiz == NULL){
  22.  
  23.         return cria_no(dado);
  24.     }
  25.  
  26.     else {
  27.             if(raiz->data > dado){
  28.  
  29.                 raiz->left= inseri_na_arvore(raiz->left,dado);
  30.  
  31.             }
  32.             else {
  33.  
  34.                 raiz->right = inseri_na_arvore(raiz->right,dado);
  35.  
  36.             }
  37.     }
  38.  
  39.     return(raiz);
  40. }
  41.  
  42.  
  43. void pre_order(tree* raiz){
  44.  
  45.     if(raiz != NULL){
  46.  
  47.         printf("%d\n", raiz->data);
  48.  
  49.         pre_order(raiz->left);
  50.  
  51.         pre_order(raiz->right);
  52.  
  53.  
  54.     }
  55. }
  56.  
  57. void order(tree* raiz){
  58.  
  59.     if(raiz != NULL){
  60.  
  61.         order(raiz->left);
  62.  
  63.         printf("%d\n", raiz->data);
  64.  
  65.         order(raiz->right);
  66.  
  67.     }
  68.  
  69. }
  70.  
  71. void pos_order(tree* raiz){
  72.  
  73.     if(raiz != NULL){
  74.  
  75.         pos_order(raiz->left);
  76.  
  77.         pos_order(raiz->right);
  78.  
  79.         printf("%d\n", raiz->data);
  80.     }
  81. }
  82.  
  83. void em_largura(tree* raiz){
  84.  
  85.     fila* lista = aloca_fila();
  86.  
  87.     enfilera(raiz, lista);
  88.  
  89.     printf("Inicio: %p\nFinal: %p\n", lista->inicio, lista->final);
  90.  
  91.     printf("Executou linha antes do laço\n");
  92.  
  93.     while(!check_fila(lista)){
  94.  
  95.         printf("Eu entrei\n");
  96.  
  97.         tree* valor = desenfilera(lista);
  98.  
  99.         printf("%d\n",valor->data);
  100.         if(valor->left != NULL){
  101.             enfilera(valor->left,lista);
  102.         }
  103.         if(valor->right != NULL){
  104.             enfilera(valor->right,lista);
  105.         }
  106.  
  107.     }
  108. }
  109.  
  110. elemento* aloca_elemento(tree* valor){
  111.  
  112.      elemento* no = (elemento *) malloc(sizeof(elemento));
  113.  
  114.      no->data = valor;
  115.  
  116.      no->anterior = NULL;
  117.  
  118.      no->proximo = NULL;
  119.  
  120.      return(no);
  121. }
  122.  
  123. fila* aloca_fila(){
  124.  
  125.     fila* lista = (fila *) malloc(sizeof(fila));
  126.  
  127.     lista->inicio = NULL;
  128.  
  129.     lista->final = NULL;
  130.  
  131.     return(lista);
  132. }
  133.  
  134. void enfilera(tree* data,fila* lista){
  135.  
  136.     if(lista->inicio == NULL && lista->final == NULL){
  137.  
  138.         elemento* no = aloca_elemento(data);
  139.  
  140.         lista->inicio = no;
  141.  
  142.         lista->final = no;
  143.  
  144.     }
  145.     else {
  146.  
  147.         elemento* no = aloca_elemento(data);
  148.  
  149.         lista->final->proximo = no;
  150.  
  151.         no->anterior = lista->final;
  152.  
  153.         lista->final = no;
  154.  
  155.     }
  156. }
  157.  
  158. tree* desenfilera(fila* lista){
  159.     if(lista->inicio != lista->final){
  160.  
  161.     tree* ponteiro = lista->inicio->data;
  162.  
  163.     lista->inicio = lista->inicio->proximo;
  164.  
  165.         return(ponteiro);
  166.  
  167.     }
  168.  
  169.     else {
  170.  
  171.     elemento* aux = lista->inicio;
  172.  
  173.     tree* no = aux->data;
  174.  
  175.     free(aux);
  176.  
  177.     lista->inicio = NULL;
  178.  
  179.     lista->final = NULL;
  180.  
  181.         return(no);
  182.     }
  183. }
  184.  
  185. int check_fila(fila* lista){
  186.     return(lista->inicio == NULL && lista->final == NULL);
  187. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement