gpt4 book ai didi

c# - 递归查找Treeview节点

转载 作者:行者123 更新时间:2023-12-02 04:31:07 25 4
gpt4 key购买 nike

我有以下树

A
+-B
+-C
| +-D
+-E
+-F
+-G

我正在尝试根据 A 找到 G

private TreeListNode FindTreeNode(TreeListNode node, Enumerations.ItemType type,
Nullable<long> id)
{
TreeListNode found = null;
foreach (TreeListNode child in node.Nodes)
{
if ((Enumerations.ItemType)child[2] == type)
{
if (id == null)
{
found = child;
break;
}
else
{
if ((long)child[0] == (long)id)
{
found = child;
break;
}
}
}
else
{
if (child.HasChildren)
{
found = FindTreeNode(child, type, id);
break;
}
}
}
return found;
}
FindTreeNode(root,C,null)

由于 C 位于 G 之前,因此例程适用于查找 C 及其子级。if else block if(child.HasChildren) 它找到 C 及其子级。当我尝试查找 E 及其子项时,递归调用无法正常工作。它与根节点 A 一起出现,但进入后,递归子节点变为 C,然后 nodes.Nodes = 1

当我搜索FG时,它必须继续递归。那么如何设置子节点为根节点

最佳答案

即使递归调用没有找到任何东西,你也会收支平衡。将相关代码修改为:

if (child.HasChildren)
{
found = FindTreeNode(child, type, id);
if (found != null)
break;
}

你的方法看起来很复杂。这不是起到同样的作用吗?

private TreeListNode FindTreeNode(TreeListNode node, Enumerations.ItemType type,
Nullable<long> id)
{
foreach (TreeListNode child in node.Nodes) {
if ((Enumerations.ItemType)child[2] == type &&
(id == null || (long)child[0] == id.Value)) {

return child;
}

if (child.HasChildren) {
TreeListNode found = FindTreeNode(child, type, id);
if (found != null) {
return found;
}
}
}
return null;
}

关于c# - 递归查找Treeview节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23091773/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com