首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在C#中遍历多层次数组

如何在C#中遍历多层次数组
EN

Stack Overflow用户
提问于 2011-05-28 04:37:30
回答 6查看 1.6K关注 0票数 1

假设rootNode是一个多层次数据结构。

代码语言:javascript
复制
rootNode.Add(node1);
rootNode.Add(node2);
node1.Add(node3);
node1.Add(node4);
node3.Add(node5);

如果使用foreach遍历rootNode,则只会得到node1、node2。如何遍历rootNode中的所有节点?

代码语言:javascript
复制
foreach(var node in rootNode){...}
EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2011-05-28 04:41:41

您可以使用recursion遍历树。

代码语言:javascript
复制
    VisitNode(Node n){
        foreach(var cn in n.Children){
            VisitNode(cn);
        }
        //Do what you want to do with your node here
        Console.Writeline(n.Value);
   }

广度优先遍历的Here is an example

票数 2
EN

Stack Overflow用户

发布于 2011-05-28 04:43:08

进行递归调用:

代码语言:javascript
复制
TraverseNodes(parentNode)
{
    for each (Node node in parentNode)
    {
         if (node.Nodes.Count>0)
             TraverseNodes(node);
    }
}
票数 1
EN

Stack Overflow用户

发布于 2011-05-28 04:43:21

您可以设置一个简单的递归函数

代码语言:javascript
复制
//Pseudo-code

public void traverse(Node n)
{
    if(n hasChildren)
    {
        foreach(Node child in n.children)
        {
              traverse(child);
        }
    }        
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6157451

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档