日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

如何C#中实现在TreeView查找某一节点

發布時間:2025/3/15 C# 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何C#中实现在TreeView查找某一节点 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在TreeView查找某一節點,通常有兩種方法,一種是遞歸的,一種不是遞歸,但都是深度優先算法。其中,非遞歸方法效率高些,而遞歸算法要簡潔一些。
?
第一種,遞歸算法,代碼如下:
????

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;
}

?

?

?
第二種,非遞歸算法,代碼如下:
???

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;
}

?

?

?????? 程序調用,如下:
?????

TreeNode tnRet = null;
foreach( TreeNode tn in yourTreeView.Nodes )
{
tnRet
= FindNode( tn, yourValue );
if( tnRet != null ) break;
}

?

?


本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/lanmao100/archive/2008/05/16/2451371.aspx

轉載于:https://www.cnblogs.com/yjkai/archive/2010/10/26/treeview1.html

總結

以上是生活随笔為你收集整理的如何C#中实现在TreeView查找某一节点的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。