Advertisement
urksiful

ArbolBinario

Oct 26th, 2015
155
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 3.70 KB | None | 0 0
  1. /*
  2. * Author: Uriel C.H.
  3. * Instituto Tecnológico Superior de Ciudad Hidalgo
  4. * Sysadmin and Advanced Researcher
  5. */
  6. import java.util.Scanner;
  7.  
  8. public class ArbolBinario {
  9.  
  10.     HojaBinaria raiz = new HojaBinaria();
  11.  
  12.     public static void main(String[] args) {
  13.         Scanner x = new Scanner(System.in);
  14.         ArbolBinario p1 = new ArbolBinario();
  15.         p1.raiz = null;
  16.         int wordleng;
  17.         String palabra;
  18.  
  19.         String arbol = "qgfxrdmvpwoahcjtbyzeuisnlk";
  20.         for (int i = 0; i < arbol.length(); i++) {
  21.             p1.Insertar(arbol.charAt(i));
  22.         }
  23.         while (true) {
  24.             try {
  25.                 palabra = x.nextLine();
  26.                 palabra = palabra.toLowerCase();
  27.                 wordleng = palabra.length();
  28.  
  29.                 if (wordleng == 1 && palabra.equals("q")) {
  30.                     System.out.println("*");
  31.  
  32.                 } else {
  33.                     for (int i = 0; i < wordleng; i++) {
  34.                         if (palabra.charAt(i) != ' ') {
  35.                             if (i < (wordleng - 1)) {
  36.                                 p1.Searcher(palabra.charAt(i));
  37.                                 System.out.print("-");
  38.                             } else {
  39.                                 p1.Searcher(palabra.charAt(i));
  40.                             }
  41.                         } else {
  42.                             System.out.print("*-");
  43.                         }
  44.                     }
  45.                 }
  46.                 System.out.println();
  47.             } catch (java.lang.NullPointerException ex) {
  48.                 String aray[] = new String [5];
  49.                 System.out.println("\nERROR DATO INVALIDO");
  50.                 main(aray);
  51.                
  52.             }
  53.         }
  54.     }
  55.  
  56.     public void Insertar(char nom) {
  57.         HojaBinaria hoja = new HojaBinaria();
  58.         hoja.data = nom;
  59.         hoja.der = null;
  60.         hoja.izq = null;
  61.         if (raiz == null) {
  62.             hoja.code = '*';
  63.             raiz = hoja;
  64.         } else {
  65.             HojaBinaria chalan = new HojaBinaria();
  66.             HojaBinaria chalanAnt = new HojaBinaria();
  67.             chalan = raiz;
  68.             while (chalan != null) {
  69.                 chalanAnt = chalan;
  70.                 if (hoja.data > chalan.data) {
  71.                     chalan = chalan.der;
  72.                 } else {
  73.                     chalan = chalan.izq;
  74.                 }
  75.             }
  76.             if (hoja.data >= chalanAnt.data) {
  77.                 hoja.code = '1';
  78.                 chalanAnt.der = hoja;
  79.             } else {
  80.                 hoja.code = '0';
  81.                 chalanAnt.izq = hoja;
  82.             }
  83.  
  84.         }
  85.     }
  86.  
  87.     public void Searcher(char nom) {
  88.  
  89.         if (raiz.data == nom) {
  90.  
  91.             System.out.print(raiz.code);
  92.  
  93.         } else {
  94.             HojaBinaria chalan = new HojaBinaria();
  95.             HojaBinaria chalan2 = new HojaBinaria();
  96.             chalan = raiz;
  97.  
  98.             while (chalan.data != nom) {
  99.                 chalan2 = chalan;
  100.                 if (nom > chalan.data) {
  101.                     if (chalan.code != '*') {
  102.                         System.out.print(chalan.code);
  103.                     }
  104.                     chalan = chalan.der;
  105.                 } else {
  106.                     if (chalan.code != '*') {
  107.                         System.out.print(chalan.code);
  108.                     }
  109.                     chalan = chalan.izq;
  110.                 }
  111.             }
  112.             if (nom >= chalan2.data) {
  113.                 System.out.print(chalan2.der.code);
  114.             } else {
  115.                 System.out.print(chalan2.izq.code);
  116.             }
  117.         }
  118.     }
  119.  
  120. }
  121.  
  122. class HojaBinaria {
  123.  
  124.     char data;
  125.     char code;
  126.     HojaBinaria izq, der;
  127. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement