C#中遍曆TreeView的兩個常用方法帖)

來源:互聯網
上載者:User

在TreeView尋找某一節點,通常有兩種方法,一種是遞迴的,一種不是遞迴,但都是深度優先演算法。其中,非遞迴方法效率高些,而遞迴演算法要簡潔一些。

第一種,遞迴演算法   

 

 

第二種,非遞迴演算法   

 

 

       程式調用,如下:

      

TreeNode tnRet = null;

        foreach( TreeNode tn in yourTreeView.Nodes )

         {

             tnRet =   FindNode( tn, yourValue );

            if( tnRet != null ) break;

         }

 

private TreeNode FindNode( TreeNode   tnParent, string strValue )

     {

        if( tnParent == null ) return null;

        if( tnParent.Text == strValue ) return tnParent;

        else if( tnParent.Nodes.Count == 0 ) return null;

         TreeNode tnCurrent, tnCurrentPar;

        //Init node

         tnCurrentPar = tnParent;

         tnCurrent = tnCurrentPar.FirstNode;

        while( tnCurrent != null && tnCurrent != tnParent )

         {

            while( tnCurrent != null )

             {

                if( tnCurrent.Text == strValue ) return tnCurrent;

                else if( tnCurrent.Nodes.Count > 0 )

                 {

                    //Go into the deepest node in current sub-path

                     tnCurrentPar = tnCurrent;

                     tnCurrent = tnCurrent.FirstNode;

                 }

                else if( tnCurrent != tnCurrentPar.LastNode )

                 {

                    //Goto next sible node

                     tnCurrent = tnCurrent.NextNode;

                 }

                else

                    break;

             }

               

            //Go back to parent node till its has next sible node

            while( tnCurrent != tnParent && tnCurrent == tnCurrentPar.LastNode )

             {

                 tnCurrent = tnCurrentPar;

                 tnCurrentPar = tnCurrentPar.Parent;

             }

            //Goto next sible node

            if( tnCurrent != tnParent )

                 tnCurrent = tnCurrent.NextNode;

         }

        return null;

     }

 

private TreeNode FindNode( TreeNode tnParent, string strValue )

     {

        if( tnParent == null ) return null;

        if( tnParent.Text == strValue ) return tnParent;

         TreeNode tnRet = null;

        foreach( TreeNode tn in tnParent.Nodes )

         {

             tnRet = FindNode( tn, strValue );

            if( tnRet != null ) break;

         }

        return tnRet;

     }

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.