广义表表达的树

namespace Tree
{
    class Program
    {
        static void Main(string[] args)
        {
            BinaryTree tree = new BinaryTree();
            tree.InitialTree(@"a(b,c(d,e))");


           

            //tree.PrintTree();
            tree.InOrder();
            tree.PostOrder();
            tree.PreOrder();
            //tree.LevelOrder();
            Console.WriteLine(tree.TreeDepth());
            
        }
    }

    public class TreeNode
    {
        public TreeNode(object element)
        {
            this.element = element;
        }
        TreeNode left;

        public TreeNode Left
        {
            get { return left; }
            set { left = value; }
        }
        TreeNode right;

        public TreeNode Right
        {
            get { return right; }
            set { right = value; }
        }
        object element;

        public object Element
        {
            get { return element; }
            set { element = value; }
        }
    }

    public class BinaryTree
    {
        TreeNode root;
        ArrayList list = new ArrayList();
        public BinaryTree()
        {
            root = null;
        }

        private void ParseExpression(string expression)
        {
            char temp;
            string node = string.Empty;
        
            for (int i = 0; i < expression.Length; i++)
            {
                temp = expression[i];
                if (IsNodeCharacter(temp))
                {

                    node += temp;
                    while (++i < expression.Length && IsNodeCharacter(expression[i]))
                    {
                        node += expression[i];
                    }
                    list.Add(node);
                    node = "";
                    if (i >= expression.Length)
                    {
                        break;
                    }
                    else
                    {
                        i--;
                    }
                }
                else
                {
                    list.Add(temp);
                }
            }

            //for (int i = 0; i < list.Count; i++)
            //{
            //    Console.WriteLine(list[i].ToString() + " ");
            //}
        }

        private bool IsNodeCharacter(char temp)
        {
            if (temp == '(' || temp == ')' || temp == ',')
            {
                return false;
            }
            else
            {
                return true;
            }
        }

        public void InitialTree(string expression)
        {
            ParseExpression(expression);

            string temp;
            int k = 0;
            Stack stack = new Stack();
            TreeNode node = null;
            for (int i = 0; i < list.Count; i++)
            {
                temp = list[i].ToString();
                switch (temp)
                {
                    case "(":
                        k = 1;
                        stack.Push(node);
                        break;
                    case ")":
                        stack.Pop();
                        break;
                    case ",":
                        k = 2; break;
                    default:
                        node = new TreeNode(temp);
                        if (root == null)
                        {
                            root = node;
                        }
                        else
                        {
                            if (k == 1)
                            {
                                (stack.Peek() as TreeNode).Left = node;
                            }
                            else if (k == 2)
                            {
                                (stack.Peek() as TreeNode).Right = node;
                            }
                        }
                        break;

                }
            }
        }


        public void InOrder()
        {
            InOrder(root);
            Console.WriteLine();
        }
        private void InOrder(TreeNode node)
        {
            if (node != null)
            {
                InOrder(node.Left);
                Console.Write(node.Element + "->");
                InOrder(node.Right);
            }
        }

        public void PreOrder()
        {
            PreOrder(root);
            Console.WriteLine();
        }
        public void PreOrder(TreeNode node)
        {
            if (node != null)
            {

                Console.Write(node.Element + "->");
                PreOrder(node.Left);
                PreOrder(node.Right);
            }
        }

        public void PostOrder()
        {
            PostOrder(root);
            Console.WriteLine();
        }
        public void PostOrder(TreeNode node)
        {
            if (node != null)
            {

              
                PostOrder(node.Left);
                PostOrder(node.Right);
                Console.Write(node.Element + "->");
            }

        }


        public void LevelOrder()
        {
            TreeNode current = root;
            TreeNode temp;
            Queue queue = new Queue();
            queue.Enqueue(current);
            while (queue.Count != 0)
            {
                temp = queue.Dequeue() as TreeNode;
                Console.Write(temp.Element + "->");
                if (temp.Left != null)
                {
                    queue.Enqueue(temp.Left);
                }
                if (temp.Right != null)
                {
                    queue.Enqueue(temp.Right);
                }
            }
            Console.WriteLine();
        }

        public int TreeDepth()
        {
            return TreeDepth(root);
        }
        private int TreeDepth(TreeNode node)
        {
            if (node == null)
            {
                return 0;
            }
            else
            {
                int leftDepth = TreeDepth(node.Left);
                int rightDepth = TreeDepth(node.Right);
                if (leftDepth > rightDepth)
                {
                    return leftDepth + 1;
                }
                else
                {
                    return rightDepth + 1;
                }
            }
        }

        public void PrintTree()
        {
            PrintTree(root);
            Console.WriteLine();
        }
        private void PrintTree(TreeNode node)
        {
            if (node != null)
            {
                Console.Write(node.Element);
                if (node.Left != null || node.Right != null)
                {
                        Console.Write("(");
                        PrintTree(node.Left);
                        if (node.Right != null)
                        {
                            Console.Write(",");
                        }
                        PrintTree(node.Right);
                        Console.Write(")");
                }
            }
        }

        public void DeleteTree()
        {
            root = null;
        }
    }
}

转载于:https://www.cnblogs.com/healer_zll/archive/2009/03/14/1411233.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值