针对上面问题,是否可以使用非递归的方式
时间: 2024-01-27 13:03:07 浏览: 56
是的,您也可以使用非递归的方式将List年级、班级和课程数据转换为树形结构。以下是一个示例代码,使用了栈来实现非递归方式的转换:
```java
import java.util.*;
class TreeNode {
private String name;
private List<TreeNode> children;
public TreeNode(String name) {
this.name = name;
this.children = new ArrayList<>();
}
public String getName() {
return name;
}
public List<TreeNode> getChildren() {
return children;
}
public void addChild(TreeNode child) {
children.add(child);
}
}
public class Main {
public static void main(String[] args) {
// 生成样例数据
Map<String, List<String>> gradeData = new HashMap<>();
gradeData.put("Grade 1", List.of("Class A", "Class B"));
gradeData.put("Grade 2", List.of("Class C", "Class D"));
gradeData.put("Grade 3", List.of("Class E"));
Map<String, List<String>> classData = new HashMap<>();
classData.put("Class A", List.of("Math", "Science"));
classData.put("Class B", List.of("English"));
classData.put("Class C", List.of("History", "Geography"));
classData.put("Class D", List.of("Physics", "Chemistry"));
classData.put("Class E", List.of("Art"));
// 转换为树形结构
TreeNode root = new TreeNode("School");
Stack<TreeNode> stack = new Stack<>();
stack.push(root);
for (String grade : gradeData.keySet()) {
TreeNode gradeNode = new TreeNode(grade);
TreeNode parent = stack.peek();
parent.addChild(gradeNode);
stack.push(gradeNode);
List<String> classes = gradeData.get(grade);
for (String className : classes) {
TreeNode classNode = new TreeNode(className);
gradeNode.addChild(classNode);
List<String> courses = classData.get(className);
for (String course : courses) {
TreeNode courseNode = new TreeNode(course);
classNode.addChild(courseNode);
}
}
stack.pop();
}
// 打印树形结构
printTree(root, 0);
}
private static void printTree(TreeNode node, int depth) {
StringBuilder indent = new StringBuilder();
for (int i = 0; i < depth; i++) {
indent.append(" ");
}
System.out.println(indent + node.getName());
for (TreeNode child : node.getChildren()) {
printTree(child, depth + 1);
}
}
}
```
以上示例代码使用了栈来模拟递归的过程,实现了非递归方式的转换和打印树形结构。您可以根据实际情况修改数据结构和打印方式。
阅读全文