예제 #1
0
        public int height(node2 node)
        {
            if (node == null)
            {
                return(0);
            }

            return(1 + Math.Max(height(node.left), height(node.right)));
        }
예제 #2
0
        public void inorder(node2 root)
        {
            if (root != null)
            {
                inorder(root.left);
                Console.WriteLine(root.item);

                inorder(root.right);
            }
        }
예제 #3
0
 public int size(node2 node)
 {
     if (node == null)
     {
         return(0);
     }
     else
     {
         int i = size(node.left);
         int j = size(node.right);
         return(i + j + 1);
     }
 }
예제 #4
0
        public static void main()
        {
            treedemo tre = new treedemo();

            //tre.insert(3);
            //tre.insert(10);
            //tre.insert(1);
            //tre.insert(2);
            //tre.insert(9);
            //tre.inorder(tre.retrunroot());
            //bool check = tre.isbalanced(tre.retrunroot());
            //int i = tre.size(tre.retrunroot());
            int[] ar   = new int[] { 1, 2, 3 };
            node2 nosd = tre.ArrtoBst(ar, 0, ar.Length - 1);
        }
예제 #5
0
        public node2 ArrtoBst(int[] arr, int start, int end)
        {
            if (start > end)
            {
                return(null);
            }
            int   mid     = (start + end) / 2;
            node2 newnode = new node2();

            newnode.item = arr[mid];

            newnode.left  = ArrtoBst(arr, start, mid - 1);
            newnode.right = ArrtoBst(arr, mid + 1, end);

            return(newnode);
        }
예제 #6
0
        public bool isbalanced(node2 node)
        {
            if (node == null)
            {
                return(true);
            }

            int lh = height(node.left);
            int rh = height(node.right);

            if (Math.Abs(lh - rh) <= 1 && isbalanced(node.left) &&
                isbalanced(node.right))
            {
                return(true);
            }
            return(false);
        }
예제 #7
0
        public void insert(int data)
        {
            node2 newnode = new node2();

            newnode.item = data;
            if (root.item == 0)
            {
                root = newnode;
            }
            else
            {
                node2 temp = root;
                node2 prev = temp;

                while (true)
                {
                    if (data > temp.item)
                    {
                        prev = temp;
                        temp = temp.right;
                        if (temp == null)
                        {
                            prev.right = newnode;
                            break;
                        }
                    }
                    else
                    {
                        prev = temp;
                        temp = temp.left;
                        if (temp == null)
                        {
                            prev.left = newnode;
                            break;
                        }
                    }
                }


                // OWN SHIT CODE

                //    if (data > root.item)
                //    {
                //        node2 prev = null;
                //        while (temp != null)
                //        {
                //            prev = temp;
                //            if (data > temp.item)
                //            {

                //                temp = temp.right;
                //                if (temp == null)
                //                {
                //                    prev.right = newnode;
                //                }
                //            }
                //            else
                //            {

                //                temp = temp.left;
                //                if (temp == null)
                //                {
                //                    prev.left = newnode;
                //                }
                //            }
                //        }


                //    }
                //    else
                //    {
                //        node2 prev = null;
                //        while (temp != null)
                //        {
                //            prev = temp;
                //            if (data > temp.item)
                //            {

                //                temp = temp.right;
                //                if (temp == null)
                //                {
                //                    prev.right = newnode;
                //                }
                //            }
                //            else
                //            {
                //                temp = temp.left;
                //                if (temp == null)
                //                {
                //                    prev.left = newnode;
                //                }
                //            }
                //        }


                //    }
            }
        }
예제 #8
0
 public treedemo()
 {
     root = new node2();
 }
예제 #9
0
 public node2()
 {
     left  = null;
     right = null;
     item  = 0;
 }