基礎的東西,關於二叉樹的幾個演算法 C#的

來源:互聯網
上載者:User

寫的比較簡單,湊合看

using System;using System.Collections.Generic;using System.Text; namespace structure{    class Program    {        #region Define tree node        #Inclde data, left node, right node and parent node        class nodes<T>        {            T data;            nodes<T> Lnode, Rnode, Pnode;            public T Data            {                set                {                    data = value;                }                get                {                    return data;                }            }            public nodes<T> RNode            {                set                {                    Rnode = value;                }                get                {                    return RNode;                }                        }            public nodes<T> LNode            {                set                {                    Lnode = value;                }                get                {                    return LNode;                }                        }            public nodes<T> PNode            {                set                {                    Pnode = value;                }                get                {                    return PNode;                }                        }            public nodes()            {}            public nodes(T data)            {                this.data = data;            }            #endregion            }                static void PreOrder<T>(nodes<T> rootNode)        {            if(rootNode != null)            {                Console.WriteLine(rootNode.Data);                if(rootNode.LNode != null)                    PreOrder<T>(rootNode.LNode);                if(root.RNode != null)                    PreOrder<T>(rootNode.RNode);                            }        }        static void MidOrder<T>(nodes<T> rootNode)        {            if(rootNode != null)            {                if(rootNode.LNode != null)                    MidOrder<T>(rootNode.LNode);                Console.WriteLine(rootNode.Data);                if(rootNode.RNode != null)                    MidOrder<T>(rootNode.RNode);                            }        }        static void AfterOrder<T>(nodes<T> rootNode)        {            if(rootNode != null)            {                if(rootNode.LNode != null)                    AfterOrder<T>(rootNode.LNode);                if(rootNode.RNode != null)                                        AfterOrder<T>(rootNode.RNode);                Console.WriteLine(rootNode.Data);                            }        }        static void LayerOrder<T>(nodes<T> rootNode)        {            Queue<T> q = new Queue<T>();            if(rootNode != null)                q.Enque(rootNode);                        while(q != null)            {                Node tmpNode = q.Deque();                Console.WriteLine(tmpNode.Data);                if(tmpNode.LNode)                    q.Enqueue(tmpNode.LNode);                if(tmpNode.RNode)                    q.Enqueue(tmpNode.RNode)            }                    }        }} 
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.