返回节点列表 Java-Parent 中的树可以有多个子节点
我正在尝试编写java代码来返回树中的节点列表。 树看起来像
Node 类是
class Node{
String label;
List<Node> children;
}
我正在尝试这种方式。但无法理解如何编写循环来遍历。
public List<Node> returnAllNodes(Node node){
List<Node> listOfNodes =
new ArrayList<Node>();
boolean iterationCompleted = false;
if(node==null){
return null;
}
while(!iterationCompleted){
if(node.getChildren()==null){
listOfNodes.add(node);
break;
}
else{
//
}
}
return null;
//return traverseAndReturnAllNodes(node.getChildren().get(0));
}
请帮忙。
I am trying to write java code to return list of Nodes in a tree.
The tree looks like
Node class is
class Node{
String label;
List<Node> children;
}
I am trying this way. But not able to understand how to write a loop to traverse.
public List<Node> returnAllNodes(Node node){
List<Node> listOfNodes =
new ArrayList<Node>();
boolean iterationCompleted = false;
if(node==null){
return null;
}
while(!iterationCompleted){
if(node.getChildren()==null){
listOfNodes.add(node);
break;
}
else{
//
}
}
return null;
//return traverseAndReturnAllNodes(node.getChildren().get(0));
}
Please help.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
如果您确定该结构是一棵树(一个节点不能有多个父级),这将以深度优先顺序列出节点:
的第一行更改为:
如果节点可以有多个父级,请将addAllNodes -第一个算法是这样的:
If you're certain that the structure is a tree (a node cannot have more than one parent), this will list the nodes in depth-first order:
If nodes can have several parents, change the first line of addAllNodes to:
The breadth-first algorithm goes like this:
您可以使用广度优先搜索或深度优先搜索。
You can use Breadth-first search or Depth-first search.
作为 Maurice Perry 对基于 DFS 的方法的答案的增强。如果单独需要子节点(因为父节点已知),则不必总是将节点添加到 listOfNodes 中,而是可以单独将子节点添加为
As a enhancement to Maurice Perry's answer for DFS based approach. In case child nodes are alone needed (as parent node is already known), then instead of adding the node always to listOfNodes, child node can alone be added as