Friday, August 26, 2011

c sharp binary tree program.

In computer science, a binary tree is a tree data structure in which each node has at most two child nodes, usually distinguished as "left" and "right". Nodes with children are parent nodes, and child nodes may contain references to their parents.

SIMPLE C# BINARY TREE CODE


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Binary_Tree
{
    class BinaryTreeNode
    {
        private char id;
        public void setID(char _id){id=_id;}
        public char getID(){return id;}
        public BinaryTreeNode left; public BinaryTreeNode right;
        public BinaryTreeNode(){left=right=null;}
        public BinaryTreeNode(char _id){id=_id;left=right=null;}
    }
    class BinaryTree
    {
        private BinaryTreeNode root;
        public BinaryTree(){root = null; }
        public void insert(char c)
        {
            addNode(c, ref root);
        }
        private void addNode(char c, ref BinaryTreeNode rptr)
        {
            if (rptr == null)
                rptr = new BinaryTreeNode(c);
            else if (rptr.left == null)
                addNode(c, ref rptr.left);
            else if (rptr.right == null)
                addNode(c, ref rptr.right);
            else
                addNode(c, ref rptr.left);
        }
 
        public void inOrderTraversal()
        {
            inOrderTraversalHelper(root);
        }
        private void inOrderTraversalHelper(BinaryTreeNode r)
        {
            if (r != null)
            {
                inOrderTraversalHelper(r.left);
                Console.Write("{0}   ", r.getID());
                inOrderTraversalHelper(r.right);
            }
        }
        public void preOrderTraversal()
        {
            preOrderTraversalHelper(root);
        }
        private void preOrderTraversalHelper(BinaryTreeNode r)
        {
            if (r != null)
            {
                Console.Write("{0}   ", r.getID());
                preOrderTraversalHelper(r.left);
                preOrderTraversalHelper(r.right);
            }
        }
        public void postOrderTraversal()
        {
            postOrderTraversalHelper(root);
        }
        private void postOrderTraversalHelper(BinaryTreeNode r)
        {
            if (r != null)
            {
                postOrderTraversalHelper(r.left);
                postOrderTraversalHelper(r.right);
                Console.Write("{0}   ", r.getID());
            }
        }
    }
    class Program
    {
        static void Main(string[] args)
        {
            BinaryTree b = new BinaryTree();
            b.insert('A');
            b.insert('B');
            b.insert('C');
            b.insert('D');
            b.insert('E');
            b.insert('G');
            b.insert('H');
            b.insert('F');
            b.insert('J');
            b.insert('K');
            b.insert('L');
            Console.WriteLine("The Inorder Traversal:\n");
            b.inOrderTraversal();
            Console.WriteLine("\n\nThe Preorder Traversal:\n");
            b.preOrderTraversal();
            Console.WriteLine("\n\nThe Postorder Traversal:\n");
            b.postOrderTraversal();
            Console.WriteLine();

        }

    }
}



a simple program for binary tree in c# for any help you can leave a comment

2 comments:

  1. How to create binary tree and its child dynamically and then search node by node.

    If we click child node then child node become a parent node and binary tree starts on this node

    ReplyDelete

used in operatonal research LP(linear programming) The Simplex Algorithm Simplex method Resolve using the Simple...