binary search tree

binary search tree

how can i make binary search tree? i want write a code that make dictionary with binary search tree data structure.please help me?

View Answers

January 9, 2012 at 12:47 PM

class bnode {   
  String key;
  bnode left;
  bnode right;
  bnode() {           
    key = null;
    left = null;
    right = null;
  }
  bnode(String key) {
    this.key = key;
    left = null;
    right = null;
  }
};
class BinarySearchTree {                
  bnode root;
  BinarySearchTree() {
    root = null;
  }
  void put(String key) {
    bnode current = root;
    bnode prev = current;
    if (root == null) {
      root = new bnode(key);
    }
    else {
      boolean insert = false;
      while (insert == false) {
        prev = current;
        if (key.compareTo(current.key) < 0) {
          if (current.left == null) {
            current.left = new bnode(key);
            insert = true;
          }
          current = current.left;
        }
        else {
          if (current.right == null) {
            current.right = new bnode(key);
            insert = true;
          }
          current = current.right;
        }
      }
    }
  }
  boolean delete(String key) {        
    boolean deleted = true;
    bnode current = root;
    bnode prev = current;
    while (current != null) {
      if (key.compareTo(current.key) > 0) {
        prev = current;
        current = current.right;
      }
      else if (key.compareTo(current.key) < 0) {
        prev = current;
        current = current.left;
      }
      else if (key.compareTo(current.key) == 0) {
        deleted = false;
        break;
      }
    }
    if (check(current) == 0) {
      if (current.key.compareTo(prev.key) > 0) {
        prev.right = null;
      }
      else {
        prev.left = null;
      }
    }
    else if (check(current) == 1) {

      if (current.key.compareTo(prev.key) > 0) {
        if (current.left != null) {
          prev.right = current.left;
        }
        else {
          prev.right = current.right;
        }
      }
      else {
        if (current.left != null) {
          prev.left = current.left;
        }
        else {
          prev.left = current.right;
        }
      }
    }
    else if (check(current) == 2) {
      bnode temp = inord(current);
      if (current == root) {
        root.key = temp.key;
      }
      else {
        if (current.key.compareTo(prev.key) > 0) {
          prev.right.key = temp.key;
        }
        else {
          prev.left.key = temp.key;
        }
      }
    }
    return deleted;
  }
  bnode inord(bnode a) {                    
    int t = 0;
    bnode ret, prev = new bnode();
    prev = a;
    a = a.right;
    while (a.left != null) {
      prev = a;
      a = a.left;
      t = 1;
    }
    ret = a;
    if (t == 0) {
      prev.right = null;
    }
    else {
      prev.left = null;
    }
    a = null;
    return ret;
  }
  int check(bnode a) { 
    int ret;
    if ( (a.left != null) && (a.right != null)) {
      ret = 2;
    }
    else if ( (a.left == null) && (a.right == null)) {
      ret = 0;
    }
    else {
      ret = 1;
    }
    return ret;
  }
  void printIn(bnode oot) {                  
    if (oot.left != null) {
      printIn(oot.left);
    }
    System.out.println("--------" + oot.key + "----------");
    if (oot.right != null) {
      printIn(oot.right);
    }
  }
  public static void main(String[] args) {
    BinarySearchTree a = new BinarySearchTree();
    String names[]={"A","B","C","D"};
    for(int i=0;i<names.length;i++){
        a.put(names[i]);
    }
    a.printIn(a.root);
  }
}

January 9, 2012 at 12:48 PM

import java.util.*;

    class TNode{
    int number;
    TNode parent;
    TNode leftChild;
    TNode rightChild;
    }
    public class BinarySearchTree{

    public TNode root = null; 
    TNode currentNode = root;

    public boolean IsEmpty(){
    if(root == null)
    return true;
    return false;
    }

    TNode create(int number){
    TNode node = new TNode();
    node.number = number;
    node.parent = null;
    node.leftChild = null;
    node.rightChild = null;
    return node;
    }

    public void insert(int number){
    currentNode = add (root,number);
    if(IsEmpty() == true && currentNode != null)
    root = currentNode;
    currentNode = root;
    }

    TNode add(TNode node, int number){
    if(node == null){
    node = create(number);
    return node;
    }
    else if(number < node.number){
    if(node.leftChild != null)
    add(node.leftChild,number);
    else
    node.leftChild = create(number);
    }
    else if(number >= node.number){
    if(node.rightChild != null)
    add(node.rightChild,number);
    else
    node.rightChild = create(number);
    }
    return null;
    }

    public void find(int number){
    IsEmpty();
    currentNode = find(root, number);

    System.out.println("Search returned Node: " + currentNode.number);
    System.out.println("Node's left child: " + currentNode.leftChild);
    System.out.println("Node's right child: " + currentNode.rightChild);
    }
    TNode find(TNode currentNode, int number){
    while(currentNode.number != number && currentNode != null){
    if(number < currentNode.number){
    currentNode = currentNode.leftChild;
    }
    else if(number > currentNode.number){
    currentNode = currentNode.rightChild;
    }
    else{
    currentNode = currentNode.rightChild;
    }
    }
    return currentNode;
    }
    public TNode getRoot(){
        return root;
    }
    private void display(TNode input){
    if(input == null){
    return;
    }
    display(input.leftChild);
    System.out.println(input.number);
    display(input.rightChild);
    }
    public static void main(String[] args){
    BinarySearchTree RBT = new BinarySearchTree();
    Scanner console = new Scanner(System.in);
    System.out.println("How many numbers would you like to enter into the Red Black Tree?");
    int k = console.nextInt();
    int inputarray[] = new int[k];
    for(int i=0; i< k; i++){
    System.out.println("Please enter the " + (i+1)+ " number: ");
    inputarray[i]= console.nextInt();
    }
    System.out.println("\n\n****Display Start****");
    for(int i=0; i<k; i++){
    RBT.insert(inputarray[i]);
    }
    RBT.display(RBT.getRoot());
    }
     }









Related Tutorials/Questions & Answers:
binary search tree
binary search tree  Construct a binary search tree by inserting the following sequence of characters into an empty tree. N O N L I N E A R D A T A Visit the tree using all three traversal algorithms and list the output sequence
binary search tree
binary search tree  Construct a binary search tree by inserting words into an empty tree. "cut your coat according to your cloth" Visit the tree.... get a word from the user and search the level/levels of that word. refer split
Advertisements
Binary Search Tree
Binary Search Tree  Question-1 ) Modify the BinarySearchTree class so that the iterators are fail-fast.Test your class with amain method ? Question-2 ) Modify the BinarySearchTree class so that the BinarySearchTree objects
Binary Search Tree
Binary Search Tree  Question-1 ) Modify the BinarySearchTree class so that the iterators are fail-fast.Test your class with amain method ? Question-2 ) Modify the BinarySearchTree class so that the BinarySearchTree objects
binary search tree
binary search tree  how can i make binary search tree? i want write a code that make dictionary with binary search tree data structure.please help me...){ IsEmpty(); currentNode = find(root, number); System.out.println("Search
Binary search tree (insertion) urgent!!
Binary search tree (insertion) urgent!!  Create a program to construct a binary search tree consisting of nodes that each stores an integer.... Assume a binary search tree is constructed from the values 14, 35, 2, 3, 39
binary search tree from text file
binary search tree from text file  How so I go about constructing a binary search tree from a text file, which has letters and numbers, which must be sorted and printed in ascending order. E.g. Text file contents 3 apples pears
How to create binary search tree using an array?
How to create binary search tree using an array?  hello people, pls guide me on the topic above. i have an string array, i want to make a binary search tree based on data inside this array. the array contains names of people
Binary tree
Binary tree  a. Construct a method to implement a binary tree using an array. b. Implement the binary tree to store numbers in sorted order
Binary tree
Binary tree  hii, What is binary tree?   hello,ADS_TO_REPLACE_1 A binary tree is a tree in which every node has exactly two links i.e left and right link
binary tree
binary tree  how to count no. of nodes in a binary tree for mlm if it complet tree or incomplet tree in php using mysql db
binary tree
binary tree  can a binary tree be implemented with out comparing...://www.roseindia.net/java/java-get-example/java-binary-tree-code.shtml http://www.roseindia.net/java/java-get-example/java-binary-tree-insert.shtml
Binary Search - Java Beginners
Binary Search  how to use Binary think in java give me the Binary Search programm thx
binary search program
binary search program  write a program to searching a string using binary search
binary search program
binary search program  write a program to searching a string using binary search
binary search program
binary search program  write a program to searching a string using binary search
binary search program
binary search program  write a program to searching a string using binary search
binary search program
binary search program  write a program to searching a string using binary search
ModuleNotFoundError: No module named 'binary-tree'
ModuleNotFoundError: No module named 'binary-tree'  Hi, My Python... 'binary-tree' How to remove the ModuleNotFoundError: No module named 'binary-tree' error? Thanks   Hi, In your python environment
Binary Search on array
Binary Search on array  What requirement is placed on an array, so that binary search may be used to locate an entry? â?º The array elements must form a heap. â?º The array must have at least 2 entries. â?º The array must
JAVA: Recusrion, Binary Search
JAVA: Recusrion, Binary Search  I want to learn about Binary Search... it using a recursive implementation of Binary Search. For the cases when more than one result can be returned, modify Binary Search to return all the elements
ModuleNotFoundError: No module named 'binary-search'
ModuleNotFoundError: No module named 'binary-search'  Hi, My... 'binary-search' How to remove the ModuleNotFoundError: No module named 'binary-search' error? Thanks   Hi, In your python
binary search - Java Beginners
binary search  Write a java program to search an array by using recursive binary search.  /* * To change this template, choose Tools | Templates * and open the template in the editor. */ package
Binary Search!!! - Java Beginners
Binary Search!!!  Hi Sir, My question is quite simple. im only... = Integer.parseInt(searchKeyText); position = search(searchKey, arrayList, 0... to continue?"); } } public static int search(int target, int
ModuleNotFoundError: No module named 'binary_tree_dict_mod'
ModuleNotFoundError: No module named 'binary_tree_dict_mod'  Hi...: No module named 'binary_tree_dict_mod' How to remove the ModuleNotFoundError: No module named 'binary_tree_dict_mod' error? Thanks   Hi
Java binary tree code
Java binary tree code       Binary Tree are the specialized tree that has two possible branches... especially in mathematics and Boolean. The java binary tree find its application
JavaScript Array Binary Search
JavaScript Array Binary Search       The JavaScript Binary Search becomes very useful in case of large Arrays.  The Binary Search algorithm is used to  handle
Java binary tree insert
node insert right to this root node. This module implements a binary search tree... Java binary tree insert       The Binary Tree insert is specialized use of binary tree
ModuleNotFoundError: No module named 'binary-file-search'
ModuleNotFoundError: No module named 'binary-file-search'  Hi, My... named 'binary-file-search' How to remove the ModuleNotFoundError: No module named 'binary-file-search' error? Thanks   Hi, In your
Which of the following statements are true with respect to binary search
Which of the following statements are true with respect to binary search  Which of the following statements are true with respect to binary search? 1. The array need not be sorted for carrying out binary search 2. Binary search
Binary Search in Java
Binary Search in Java In this section, we are going to search an element from an array using Binary Search. The advantage of a binary search over a linear search is astounding for large numbers. It can be done either recursively
How to using Binary Search Array Java ?
How to using Binary Search Array Java ?  Hi, I am beginners in Java... functions. The problem is that how to use binary search array in Java. Please give any online reference show that i will implement the binary search array in Java
php array binary search
PHP Binary Search Array is used to search the given value in the array. In php there is no function for the binary search like java or other language. User can implement and use the binary search in php as given below
Java Array Binary Search example
Java Array Binary Search It is a method for searching the array element... the binary search algorithm.  It returns the index of the found element... example demonstrates how to do a binary search on the Java array object
Building a Binary Tree using std::map, std:set
Building a Binary Tree using std::map, std:set  Hi, can someone... a simple binary tree? I do not seem to understand how these 2 containers can be used to represent a binary tree because I can't help but to see that map and set act
Send me Binary Search - Java Beginners
Send me Binary Search  how to use Binary think in java give me the Binary Search programm thx..  Hi friend, import java.io.*; public class BinarySearchDemo { public static final int NOT_FOUND = -1
Binary Search in Java
Binary Search in Java is used to search an element from an array. Programmers opt for Binary search over linear search when it comes to large numbers. It can... the answer "Not Found".ADS_TO_REPLACE_1 Following is the example of Binary Search
ModuleNotFoundError: No module named 'tree-edge-search'
ModuleNotFoundError: No module named 'tree-edge-search'  Hi, My... named 'tree-edge-search' How to remove the ModuleNotFoundError: No module named 'tree-edge-search' error? Thanks   Hi, In your
binary
binary  Hi I want to write a program in pascal that ask a user to input a decimal number and then return its binary equivalent in the minimum number of bits required to repesent the number. Thks
Retrive data from database and perform binary tree operations on that data in jsp or java
Retrive data from database and perform binary tree operations on that data... Left and Subbinary tree node count. Check balanced tree of particular Id ,unbalaced tree node and so on. Please Help me
tree
tree  hi.i want search in bstree . what am i doing?   Please visit the following link: http://www.roseindia.net/tutorial/java/core/binarySearch.html
Tree
Tree  print("code sample");1) Write Java code to create the following tree using new Tree state- ments: 1
octal to binary
octal to binary  i want to know how to convert a octal to binary number   Here is a java example that converts octal to binary. import... binary=Integer.toBinaryString(i); System.out.println(binary
program binary
program binary  Hi I want to write a program in pascal that ask a user to input a decimal number and then return its binary equivalent in the minimum number of bits required to repesent the number. In pascal language please
universal binary for ipad iphone
universal binary for ipad iphone  How can i create a universal binary for iPad and iPhone
ModuleNotFoundError: No module named 'binary'
ModuleNotFoundError: No module named 'binary'  Hi, My Python... 'binary' How to remove the ModuleNotFoundError: No module named 'binary'... to install padas library. You can install binary python with following command
swing program for decimal to binary
swing program for decimal to binary  swing program for decimal to binary
search
search  how to develop search box and how to retrive data from database..   Please visit the following link: Search box
SEARCH
SEARCH  how can we do search in jsp...? option for search criteria like name and DOB...   Please visit the following links: http://www.roseindia.net/jsp/user-search.shtml http://www.roseindia.net/servlets/search.shtml
BINARY TO DECIMAL - Java Beginners
BINARY TO DECIMAL  HELP ME PLSS. PROGRAM THAT CONVERTS BINARY TO DECIMAL  Hi friend, Program to convert Binary To Decimal : import... (System.in); System.out.print ("Enter a binary number "); String str

Ads